原型
每个对象都会在其内部初始化一个属性,就是prototype(原型) 使用hasOwnProperty() 可以判断这个属性是不是对象本身的属性
Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个 函数是?
hasOwnProperty
javaScript中hasOwnProperty
函数方法是返回一个布尔值,指出一个对象是否具有指 定名称的属性。此方法无法检查该对象的原型链中是否具有该属性;该属性必须是对 象本身的一个成员。
使用方法:
object.hasOwnProperty(proName)
其中参数object
是必选项。一个对象的实例。 proName
是必选项。一个属性名称的字符串值。
如果 object
具有指定名称的属性,那么JavaScript
中hasOwnProperty
函数方法返回 true
,反之则返回 false
。
原型链
当我们在访问一个对象的属性时,如果这个对象内部不存在这个属性,那么他就会去
prototype
里找这个属性,这个prototype
又会有自己的prototype
,于是就这样一直找下 去,找到Object.__proto__
为止,找不到就返回unde
也就是我们平时所说的原型链的 概念。
关系:instance.constructor.prototype = instance.__proto__
特点: JavaScript
对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于 自己的原型副本。当我们修改原型时,与之相关的对象也会继承这一改变。 当我们需要一个属性的时,Javascript
引擎会先看当前对象中是否有这个属性, 如果 没有的话,就会查找他的Prototype
对象是否有这个属性,如此递推下去,一直检索到 Object
内建对象。
所有的引用类型(数组、对象、函数),都具有对象特性,即可自由扩展属性(null
除 外)
所有的引用类型(数组、对象、函数),都有一个__proto__
属性,属性值是一个普通 的对象
所有的函数,都有一个prototype
属性,属性值也是一个普通的对象
所有的引用类型(数组、对象、函数),__proto__
属性值指向它的构造函数的 prototype
属性值
原型链中的this
所有从原型或更高级原型中得到、执行的方法,其中的this在执行时,就指向了当前这 个触发事件执行的对象。