技术咨询、项目合作、广告投放、简历咨询、技术文档下载
点击这里 联系博主
# Object.create和New的区别
# sidebar: false
引用官方的一句话:Object.create()方法创建一个新对象,使用现有的对象来提供新创建的对象的__proto__。 Object.create(proto, [propertiesObject])
- proto 新创建对象的原型对象。
- propertiesObject 可选。如果没有指定为 undefined,则是要添加到新创建对象的可枚举属性(即其自身定义的属性,而不是其原型链上的枚举属性) 对象的属性描述符以及相应的属性名称。这些属性对应Object.defineProperties()的第二个参数。
# Object.create()的polyfill实现
- 方法内部定义一个新的空对象obj
- 将obj.__proto__的对象指向传入的参数proto
- 将传入的对象属性复制到obj并且返回obj
if (typeof Object.create !== "function") {
Object.create = function (proto, propertiesObject) {
if (typeof proto !== 'object' && typeof proto !== 'function') {
throw new TypeError('Object prototype may only be an Object: ' + proto);
} else if (proto === null) {
throw new Error("This browser's implementation of Object.create is a shim and doesn't support 'null' as the first argument.");
}
if (typeof propertiesObject != 'undefined') throw new Error("This browser's implementation of Object.create is a shim and doesn't support a second argument.");
//核心是下面的代码
function F() {}
F.prototype = proto;
return new F();
};
}
# New
语法: new constructor ( [aguments] ) MDN文档 (opens new window)
由此我们可以看出,实际new创建对象,就是调用构造函数来实例化,在调用构造函数的时候会执行以下操作:
- 创建一个新的对象
- 将新对象执行原型操作,指向构造函数的原型
- 将this绑定到新对象上(可以使用 call 或者 apply 强制转换执行环境)
- 构造函数返回的对象就是实例化的结果,如果构造函数没有显示返回一个对象,则返回新的对象
New的polyfill实现
function _new_ (){
var obj = {},
Constructor = [].shift.call(arguments);//第一个参数为要new的那个对象
obj.__proto__ = Constructor.prototype;//得到对象的原型
var ret = Constructor.apply(obj, arguments);//将this绑定到新的对象上,arguments已经移除了第一个参数,那么后续的入参为对象的入参
return typeof ret === 'object' ? ret : obj;
}
//测试
function Demo(name,age){
this.name=name;
this.age=age;
}
var demo=_new_(Demo,'mrgao',20);
console.log(demo);
# New和Object.create()的区别
比较 | new | Object.create |
---|---|---|
构造函数 | 保留原构造函数属性 | 丢失原构造函数属性(这就是为什么使用寄生式组合时需要重新设置构造函数) |
原型链 | 原构造函数prototype属性 | 原构造函数/(对象)本身 |
作用对象 | function | function和object |
- 本文链接: https://mrgaogang.github.io/javascript/base/Object.create%E5%92%8CNew%E7%9A%84%E5%8C%BA%E5%88%AB.html
- 版权声明: 本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 许可协议。转载请注明出处!