简单解析JavaScript中的__proto__属性
JavaScript是一个面向对象语音,即一切皆对象。
那么怎么生成对象?在Java的世界里,对象是由类(Class)实例出来的,通俗地说,就是将事物抽象成一个模具,用这个模具(类)生产出一个个具体的实物(对象)。
可是JS中没有类这个概念,有的是“原型”,对象是由原型衍生出来的。通俗地说,在JS的世界里,“原型”并不是一个模具,而是一个具体的实物(对象)。所有对象都是由另一个对象衍生出来的,而这个被衍生的对象就是所谓的“原型对象”。
在javascript中有三类对象,1用户创建的对象,2构造函数的对象,3原型对象
- 用户创建的对象,一般意义上使用new语句显式构造的方法。
- 构造函数的对象,普通的构造函数,即通过new调用生成普通对象的函数
- 原型对象,构造函数prototype属性指向的对象。
这三个对象中每一个类都有一个属性-__proto__属性,它们指向该对象的原型,从任何对象沿用它开始遍历都可以追溯到Object.prototype。
构造函数都有prototype对象,它指向一个原型对象,通过该构造函数创建对象的时候,被创建的对象的__proto__属性将指向构造函数的prototype属性。
原型对象有一个constructor属性,该属性指向它对应的构造函数。
Talk is cheap, show me the code! 咱们来看看代码:
var obj = {}; console.log(obj);
咱们将__proto__展开看看:是一些默认方法。
你一定会发生这个__proto__对象中也有一个__proto__对象,正如我们刚才说的,每个对象都有一个__proto__属性指向它的原型对象。我们打印一下这个__proto__中的__proto__:
console.log(obj.__proto__.__proto__); //--> null
结果是null,说明已经到了顶层原型对象。obj是用大括号{}定义的,obj的原型对象自然是JS的顶层对象。
咱们再看一端代码,加强下理解:
var parent = { name : "parent" }; var child = { name : "child", __proto__ : parent }; var subChild = { name : "subChild", __proto__ : child } console.log(subChild);
- subChild.__proto__ --> child
- child.__proto__ --> parent
- parent.__proto__ --> 顶层原型对象
- js中继承的几种用法总结(apply,call,prototype)
- JQuery,Extjs,YUI,Prototype,Dojo 等JS框架的区别和应用场景简述
- JavaScript中的prototype使用说明
- js中的hasOwnProperty和isPrototypeOf方法使用实例
- 不错的一篇关于javascript-prototype继承
- js中prototype用法详细介绍
- JavaScript prototype 使用介绍
- Javascript中Array.prototype.map()详解
- JS面向对象、prototype、call()、apply()
- 数据排序谁最快(javascript中的Array.prototype.sort PK 快速排序)
- JavaScript isPrototypeOf和hasOwnProperty使用区别
- JS 面向对象之神奇的prototype
相关文章
javascript 基础篇3 类,回调函数,内置对象,事件处理
在js中自定义一个类跟java c++就有比较大的区别了,因为这个格式用公式表达起来比较困难,大体说一下吧2012-03-03JavaScript lastIndexOf方法入门实例(计算指定字符在字符串中最后一次出现的位置)
这篇文章主要介绍了JavaScript字符串对象的lastIndexOf方法入门实例,lastIndexOf方法用于计算指定字符在字符串中最后一次出现的位置,需要的朋友可以参考下2014-10-10javascript中call,apply,bind的用法对比分析
这篇文章主要给大家对比分析了javascript中call,apply,bind三个函数的用法,非常的详细,这里推荐给小伙伴们。2015-02-02
最新评论