关于JavaScript的Object和Function的两张图

本文通过两张图表详细解析了JavaScript中的对象与函数概念,并解释了如何判断对象实例与构造函数的关系,以及类实例的constructor属性指向的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面两张图基本说清楚了Object和Function.这边备份一下.
如果想了解详情,点他们的网站,两篇非常不错的帖子,感谢.
第一张由怿飞引入,从最底层开始[url]http://www.planabc.net/2010/05/06/interesting_code_associated_with_function_and_object/[/url]

[img]http://dl.iteye.com/upload/attachment/304009/6db3f6c5-26f4-3fec-b44c-bb176288df3c.jpg[/img]

第二张由互联网人制作,强调OOP中继承时的情形[url]http://w3er.com/javascript/master-javascript-object-system/comment-page-1/[/url]

[img]http://dl.iteye.com/upload/attachment/304011/983c0554-dfa4-3a0c-817c-670d1eef6d69.png[/img]

补充几点:
1.如何判定a instanceof b ? 顺着a的"__proto__"一直向上找,会关联到一系列构造函数的原型对象,而所有涉及的这些构造函数x,都有a instanceof x === true;
2.类的实例的constructor其实是指向类的prototype属性的constructor.所以类构造函数中保障对象有正确的consturctor非常重要(必要的重置不能省掉).不然第二张图乱掉,不是OO模拟中想看到的.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值