为了账号安全,请及时绑定邮箱和手机立即绑定

js 原型链继承

js 原型链继承

慕妹3146593 2019-03-20 18:14:58
        function Foo1(){           this.name1 = '1';        }        function Foo2(){           this.name2 = '2';        }        Foo2.prototype = new Foo1();        function Foo3(){           this.name = '3';        }        Foo3.prototype = new Foo2();        var foo3 = new Foo3();        console.dir(foo3);各位帮忙分析下,为什么箭头指向的地方打印出来不是Foo2而是Foo1,这是什么原理?
查看完整描述

3 回答

?
慕村225694

TA贡献1880条经验 获得超4个赞

因为你将Foo1的实例复制给Foo2的原型,这时候Foo2.prototype.constructor指向的是Foo1,如果你在Foo2.prototype=new Foo1后面加一行Foo2.prototype.constructor=Foo2,将constructor重新修改为Foo2。应该就能达到你想要的结果了。

查看完整回答
反对 回复 2019-03-29
?
aluckdog

TA贡献1847条经验 获得超7个赞

Foo3通过prototype属性将原型指向了Foo2,但是最终Foo2的原型也是Foo1


查看完整回答
反对 回复 2019-03-29
  • 3 回答
  • 0 关注
  • 484 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号