每日一题·对原型和原型链的理解(12/1)

目录

1. 原型链为什么要出现?

2. 原型是什么

3. 原型链是什么

4. 一些代码片段


1. 原型链为什么要出现?

声明2个实例,每个实例都会独立创建sayHi方法,非常占用内存。一样的方法,可以放在原型对象上共用。

        function Person(name, age) {
            this.name = name
            this.age = age
            this.sayHi = () => {
                console.log(1);
            }
        }
        let p1 = new Person('ls', '19')
        let p2 = new Person('zs', 20)
        console.log(p1.sayHi === p2.sayHi); // false
        p1.sayHi()
        p2.sayHi()

2. 原型是什么

 

  1. 每个函数身上都有要给prototype属性指向它的伴生对象

  2. 每个对象身上都有一个proto属性,指向它的构造函数的伴生对象

  3. 伴生对象身上有constructor属性,指向它的构造函数。伴生对象也有proto属性,指向父节点的prototype

  4. 我们一般会在prototype属性上面挂载公用的方法

  5. class语法,里面的方法,就是直接挂载到原型上面的。但是如果加了static关键字,就不是挂载到prorotype上

  6. 原型的特点:JS对象是通过引用来传递的,当修改原型时,与之相关的对象也会继承这个修改

  7. function Object和 function Function也是构造函数Function的实例对象, 他们俩都有proto属性指向Function.prototype

3. 原型链是什么

  1. 原型链是什么

  2. proto属性的指向,就会构成了原型链

  3. 当我们需要一个属性时,JS引擎会先查看当前对象中是否有这个属性,找不到,就会往proto属性关联的prototype对象查找

  4. 最终的根节点就是 Object.prototype.proto属性,指向的是undefiend

  5. 查找的链路越长,对性能的影响就会越大

4. 一些代码片段

var a = {}
a.constructor.prototype === a.__proto__ // true 因为 a.constructor就是Object构造函数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值