js中的new方法

new方法的作用:创建一个实例对象,并继承原对象的属性和方法;

new对象内部操作:

1,创建一个新对象,将新对象的proto属性指向原对象的prototype属性;

2,构造函数执行环境中的this指向新对象;

3,执行构造函数中的代码;

4,若构造函数返回的是一个对象则返回此对象,若非,则返回新创建的对象;

此过程完成了创建对象、对象继承、属性初始化过程,被称为隐式原型继承;

手写实现new:

javascript 复制代码
function new_(Constructor,args){
    var obj = Object.create(null);// 创建一个新对象
    obj.__proto__ = Consturct.prototype;// 将旧对象原型赋值给新对象
    var result = Constructor.apply(obj, args);// 将this指向新对象
    return typeof result === 'object' ? result : obj;
}
相关推荐
何大春4 小时前
【弱监督语义分割】Self-supervised Image-specific Prototype Exploration for WSSS 论文阅读
论文阅读·人工智能·python·深度学习·论文笔记·原型模式
小白不太白95018 小时前
设计模式之 原型模式
设计模式·原型模式
澄澈i18 小时前
设计模式学习[8]---原型模式
学习·设计模式·原型模式
Domain-zhuo18 小时前
什么是JavaScript原型链?
开发语言·前端·javascript·jvm·ecmascript·原型模式
机器视觉知识推荐、就业指导1 天前
C++设计模式:原型模式(Prototype)
c++·设计模式·原型模式
p-knowledge1 天前
原型模式(Prototype Pattern)
原型模式
JAVA开发区2 天前
探索设计模式:原型模式
设计模式·原型模式
周三有雨3 天前
Object.prototype.hasOwnProperty.call(item, key) 作用与用途
前端·javascript·vue.js·typescript·原型模式
捕鲸叉5 天前
C++创建型模式之原型模式
c++·设计模式·原型模式
JerryXZR9 天前
JavaScript核心编程 - 原型链 作用域 与 执行上下文
开发语言·javascript·原型模式