Object.setPrototypeOf() 和 Object.create() 区别

基础用法
  1. Object.setPrototypeOf(A.protytype,B.prototype)
  2. A.prototype = Object.create(B.prototype)
共同作用

都能达到A.prototype.__proto__ = B.prototype 的效果,一般用于继承

区别

使用第二种A.prototype = Object.create(B.prototype),因为使用了等号赋值,所以首先达成的效果是改变A.prototype使它等于Object.create()返回的新的对象,其次才会达到A.prototype.__proto__ = B.prototype的效果,所以Object.create()会覆盖A.prototype,但是Object.setPrototypeOf()不会有这个副作用。

代码区分
///使用Object.create()
function Father1() {
  this.name = "father1";
}
Father1.prototype.arr = [1, 2];
function Son1() {
  this.type = "son1";
}
Son1.prototype.getType = function () {
  return "son1 from prototype";
};
Son1.prototype = Object.create(Father1.prototype);
Son1.prototype.constructor = Son1;
let son1 = new Son1();
console.log(son1.arr); //[1,2]
console.log(son1.type); //'son1'
console.log(son1.getType); //undefined 最主要区分

//使用Object.setPrototypeOf()
function Father2() {
  this.name = "father2";
}
Father2.prototype.arr = [1, 2];
function Son2() {
  this.type = "son2";
}
Son2.prototype.getType = function () {
  return "son2 from prototype";
};
Object.setPrototypeOf(Son2.prototype, Father2.prototype);
let son2 = new Son2();
console.log(son2.arr); //[1,2]
console.log(son2.type); //'son2'
console.log(son2.getType); //function(){}
补充
  1. 根据mdn,使用Object.setPrototypeOf()改变原型的指向会影响性能。https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/setPrototypeOf
  2. Object.create()内部的基础逻辑
    function create(newPrototype){
      let NewConstruc = function(){}
      NewConstruc.prototype = newPrototype
      return new NewConstruc()
    }
    
  3. 以上用法都只考虑了一个参数的情况,这两种方法都能接受第二个参数来添加属性
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值