码迷,mamicode.com
首页 > 编程语言 > 详细

Javascript的原型链图

时间:2016-10-12 14:15:43      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:

 

 

90%的前端或者js程序员或者老师们对Javascript懂得不比这个多 

 

给手机看的



技术分享

但是这个图里的所有褐色单向箭头链就是Javascript的原型链(颜色标注对理解js原型链很关键)

这图中的各个__proto__ constructor .prototype 都是内部对象 这样画是为了简洁

举个例子 如果考虑__proto__ 作为内部对象 上图变为

技术分享

原型链就是


技术分享
constructor 和 prototype如果作为内部对象 放到相应的位置 图就变大麻团了 保证晕倒什么也记不住

不服请看 这是实际的Javascript原型链图 嘿嘿

技术分享

原型链大部分时候是不可见的(__proto__在firefox nodejs中可见)那么图退化为


技术分享

上几图三特点

1.所有对象都在原型链上

2.除了null 每个对象都有且唯一的__proto__原型对象

3.除了null, Object.prototype,其它对象的原型对象虽然不可通过.__proto__操作访问 但是通过原型链上某个构造器(函数)的prototype属性都可以访问到

 

js coder大多时候要面对的是

技术分享优雅了吧 :-()

所有javascript重度编码都是操作上面这个图的元素 但是你心里至少要有下图

技术分享如果连这图都嫌弃不好记 最简单的铁三角 javascript 99%的幻化都由此来

技术分享阴影的部分不要动(当然你愿意发大招搞出个Kavascript也是个人自由 但那不是Javascript) 会破坏原型链的结构和密封性 js编程对原型链的拆改都是针对左下角的非阴影部分

技术分享考虑到__proto__ prototype constructor都是内部对象

所以实际的关系图应该是

技术分享

Javascript的原型链图

标签:

原文地址:http://www.cnblogs.com/fakeCoder/p/5952306.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!