js原型链的概解

概念

原型链查找就是通过 __proto__ 查找,查找至值为 null ( Object.prototype)时结束。

__proto__ 是原型链查找中用到的,它总是指向 prototype
prototype 在定义构造函数时自动创建,它总是被 __proto__ 所指。

prototype__proto__的区别

prototype只有构造函数才有的属性, __proto__是任何一个对象都有的属性

结合一个很简单的小例子来看看:

var o1 = {
        o2: { a: 1, b: 2}
    };
    console.log(o1);
    var o4 = {
        msg: '我是o4',
        bar: function () {
            console.log(this.msg);//此时this指向的是o4
            // console.log(o4.msg);
        }
    };
    var o2 = {
        fn: function () { console.log('我是o2的fn方法') }
    };
    var o3 = {
        msg: '我是o3'
    };
    o2.__proto__ = o4;
    o3.__proto__ = o2;
    // o3 ---> o2 ---> o4 原型链 【对象的属性(方法) 的查找】
    o4.bar(); //  '我是o4'
    o3.bar(); //  '我是o3'
    o2.bar(); //  '我是o4'

从这个例子可看出,o3—>o2—>o4这里就形成了一个原型链,首先o3在自己那里找没找到之后,就去o2原型那儿去找,因为在前面将o2给了o3的原型,之后就再去找o4的,直到找到Object.prototype.

原型链存在的不足

  1. 当原型链中包含引用类型值的原型时,该引用类型值会被所有实例共享;
  2. 在创建子类时,不能向父类(也叫超类型)的构造函数中传递参数。

解决办法:借用构造函数,也就是在子类构造函数的内部调用父类构造函数。

function Father(){
    this.num= [1, 3, 4, 5, 6];
}
function Son(){
    Father.call(this);//继承了Father,并且向父类型传递参数
}
var number = new Son();
number.num.push(2);
console.log(number.num);//1, 3, 4, 5, 6, 2

var number1= new Son();
console.log(number1.num);//1, 3, 4, 5, 6

这个例子中call借调了父类,并继承了,解决了引用类型值会被共享这个问题,同时也给父类中传入了参数。

整理的就这么多,主要靠自己的理解,如有错误,请指出一下,谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值