深入理解JavaScript:prototype和__proto__属性

针对JavaScript的prototype和__proto__属性很容易使初学者不明白,本人水平也是入门级水平,根据自己的理解整理了下两都的区别:注意:以下代码是在chrome console上执行的,这个工具的好处我就不用说了,大家都懂的。

1. 测试代码如下:



2. 查看结果:


3.得出结论:

(1)如果是函数的话,它具有prototype、__proto__(在v8下是个Empty()函数);
(2)如果是new 出来的对象的话,它只有__proto__属性;并且例如:f1.__proto__ == Foo.prototype;
(3)大家可以按照这样观察出很多有意思的东西;
  (4)最后再帐号一段代码:


知道为什么以上会输出这种情况?请仔细看看我以下的截图:f2对象根本没有test()方法这个属性,访问肯定出错嘛。而Foo有这个属性,所以是可以访问的。

这是console.dir(Foo); test方法在里面。



这是 console.dir(f2);


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值