• 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创建的对象的特殊方法。

    1. const Person = class {
    2. constructor(name) {
    3. this.name = name;
    4. }
    5. };
    6. class createPersonClass extends Person {
    7. constructor(name, age) {
    8. console.log(name);
    9. console.log(age);
    10. //通过supper()传入父类Person的构造函数
    11. super(name);
    12. // 注意: 在派生类中, 必须先调用 super() 才能使用 "this"。
    13. console.log(this.name);
    14. //console.log(this.age);//undefined
    15. }
    16. }
    17. const jack = new createPersonClass("Jack", 18);

    call

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

    apply

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

    bind

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

    图示

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

  • 相关阅读:
    手把手教你搭建Windows 搭建Prometheus + Grafana + Jmeter可视化监控平台
    WebGIS----wenpack
    Processing入门教程
    使用Python输出三角形字符阵列
    [Docker] Docker常用命令
    四川古力未来科技抖音小店打造品质生活,可靠之选引领潮流
    项目记录:使用SpringBoot + MyBatisPlus 在MySQL字段设置外键后ID自增失效导致添加失败问题(ID生成策略)
    Java面试题1
    【题解】同济线代习题一.8.4
    xss-labs靶场1-5关
  • 原文地址:https://blog.csdn.net/Irene1991/article/details/128172516