JavaScript中原型学习基本理解(原型链: prototype _proto_)(二)
来源:互联网 发布:实况足球2017mac版 编辑:程序博客网 时间:2024/06/07 15:09
上一小节简单介绍了原型的基本知识,本节将截止上节来讲原型在JavaScript这门语言中起到的作用。
JavaScript是一门面向对象的语言,既然如此那就肯定少不了面向对象的基本特性继承。不同Java/c#这类用类来实现继承的语言,在JavaScript中同国原型链的概念来实现。
说道原型链那我们就不得不谈谈: prototype() _proto_
prototype(任意一个构造函数都包含此属性,实现原型链的基础。指向该函数的原型对象)
例如:
function SuperType(){
this.proper= true;
}
SuperType.prototype//
superType在创建是便生成一个superType.prototype的原型对象,并且此对象中的constructor指向构造函数的本身.
_proto_(任意一个构造函数实例化的对象都包含此属性,指向构造函数的原型对象)
此时我们:var instance=new SuperType();
1)instance._proto_ === SuperType.prototype//返回的是true
2)SuperType.__proto__ === SuperType.prototype//返回的是false
搞清楚_proto_和prototype的区别上面的栗子就不难理解了。
_proto_指向构造函数的原型对象
prototype指向该函数的原型对象
instance的构造函数是SuperType 因此在第一个栗子中返回的值为true
SuperType的构造函数是Function 因此第二个栗子中返回的值是false
对于原型中的prototype 和_proto_相信大家都已经可以理解了。
那么原型链到底是如何构成的呢?
在我们SuperType这个构造函数中,我们让SuperType的实例等于一个函数A的原型对象。
函数A的原型对象将包好指向函数SuperType原型对象的指针,及可以拥有函数SuperType原型对象的属性。
我们以此类推就构成了实例与原型的链条。即我们所说的原型链。
对于原型链实现的具体过程我们下节继续分析。
- JavaScript中原型学习基本理解(原型链: prototype _proto_)(二)
- 原型与原型链prototype与_proto_
- JavaScript中原型学习基本理解(原型链)三
- JS中原型链中的prototype与_proto_的理解和区别
- Js中原型与原型链及_proto_和prototype的关系
- 理解JavaScript原型prototype
- javascript原型(prototype)理解
- Javascript原型Prototype理解
- javascript中原型(prototype)与原型链
- JavaScript中原型学习基本理解(一)
- javascript中原型继承(prototype inherit)的理解
- 如何理解javascript中的prototype(原型)和原型链?
- JS原型链中 _proto_和prototype及constructor的关系
- Javascript 悟二 prototype 原型链
- javascript prototype 原型链
- Javascript prototype 原型链
- javascript 原型(prototype)
- javaScript prototype原型的理解
- HEVC 资源
- 三角形
- 6. 良乡足球场
- Android studio 导入项目报错 project sdk is not defined
- linux虚拟机配置ip
- JavaScript中原型学习基本理解(原型链: prototype _proto_)(二)
- MySQL同步故障:" Slave_SQL_Running:No" 两种解决办法
- webgl之创建三维文本,重点是实现中文字体的输出
- spring测试数据库插入失败
- 7. 郭老师家的果园
- 从 vs2008 到 vs2015
- Python2中中文解决方式
- javascript 模板引擎基本原理
- NYOJ-40-公约数和公倍数(水题)