来源:https://zhuanlan.zhihu.com/p/35790971
一、原型 prototype
和 __proto__
- 每个对象都有一个
__proto__
属性,并且指向它的prototype
原型对象 - 每个构造函数都有一个
prototype
原型对象 prototype
原型对象里的constructor
指向构造函数本身
代码:
1 | function Person(nick, age){ |
二、原型链
上图关系:
1 | arr.__proto__ === Array.prototype |
原型链如下:
1 | arr ---> Array.prototype ---> Object.prototype ---> null |
这就是传说中的原型链,层层向上查找,最后还没有就返回undefined
三、JavaScript 中的继承
- 属性继承
1 | function Person (name, age) { |
- 方法继承
1 | Teacher.prototype = Object.create(Person.prototype) |
3.4 hasOwnProperty
在原型链上查询属性比较耗时,对性能有影响,试图访问不存在的属性时会遍历整个原型链。
遍历对象属性时,每个可枚举的属性都会被枚举出来。 要检查是否具有自己定义的属性,而不是原型链上的属性,必须使用hasOwnProperty
方法。
hasOwnProperty 是 JavaScript 中唯一处理属性并且不会遍历原型链的方法。
instanceof原理
instanceof是判断实例对象的proto和生成该实例的构造函数的prototype是不是引用的同一个地址。
是返回true,否返回false。
需要注意的地方
1 | function foo() { |
输出的是:
这里的原因是: foo.prototype = {k:1,x:2}相当于又重新创建了一个地址。它指向的地址和obj.proto指向的不同了。
1 | function foo() { |
)
Author: Amanda-Zhang
Copyright: All articles in this blog are licensed under CC BY-NC-SA 3.0 unless stating additionally.