js对象易混淆知识

js对象易混淆知识

__proto__ vs prototype

__proto__和constructor属性是对象所独有的。

__proto__属性的作用就是当访问一个对象的属性时,如果该对象内部不存在这个属性,那么就会去它的__proto__属性所指向的那个对象(父对象)里找,一直找,直到__proto__属性的终点null,再往上找就相当于在null上取值,会报错。

Object.create()

Object.create()方法创建一个新对象(带着指定的原型对象和属性),使用现有的对象来提供新创建的对象的__proto__。

Object.assign

Object.assign 会把  OtherSuperClass原型上的函数拷贝到 MyClass原型上,使 MyClass 的所有实例都可用 OtherSuperClass 的方法。Object.assign 是在 ES2015 引入的,且可用 polyfilled。要支持旧浏览器的话,可用使用 jQuery.extend() 或者 _.assign()。

instanceof

instanceof 用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

isPrototypeOf

isPrototypeOf() 测试一个对象是否存在于另一个对象的原型链上。

constructor

constructor 是一种用于创建和初始化class创建的对象的特殊方法。

const Person = class {
    constructor(name) {
      this.name = name;
    }
};

class createPersonClass extends Person {
    constructor(name, age) {
      console.log(name);
      console.log(age);
      //通过supper()传入父类Person的构造函数
      super(name);
      // 注意: 在派生类中, 必须先调用 super() 才能使用 "this"。
      console.log(this.name);
      //console.log(this.age);//undefined
    }
  }

const jack = new createPersonClass("Jack", 18);

call

通过call()和apply()间接调用函数,任何函数可以作为任何对象的方法来调用。

apply

第一个参数是调用函数的母对象 this,apply 方法要求以数组的形式传入参数

bind

bind 方法将函数绑定到某个对象,除第一个实参外,其他实参绑定到 this ,返回一个函数对象。

图示

图片忘记从哪来的啦,图片不是原创。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Irene1991

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值