二、原型和原型链
题目:
- 如何准确判断一个变量是数组类型
-arr instanceof Array //true
- 写一个原型链继承的例子
//封装DOM查询的例子
function Elem(id){
this.elem = document.getElementByID(id)
}
Elem.prototype.html = function(val){
var elem = this.elem
if(val){
elem.innerHTML = val
return this //链式操作
}else{
return elem.innerHTML
}
}
Elem.prototype.on = function(type,fn){
var elem = this.elem
elem.addEventListener(type,fn)
return this
}
var div1 = new Elem('div1')
div1.html('<p>hello 1</p>').on('click',function(){
alert('clicked').html('<p>hello 2</p>')
})
- 描述new一个对象的过程
- 创建一个新对象
- this指向这个新对象
- 执行代码,即对this赋值
- 返回this
return this//默认有这么一行
- zepto(或其他框架中)源码中如何使用原型链
知识点:
-
构造函数(class)
-大写字母开头 -
构造函数-扩展
-var a = {}其实是var a = new Object()的语法糖
-var a = []其实是var a = new Array()
-function Foo(){}其实是var Foo= new Function()
使用instanceof 判断一个函数是否是一个变量的构造函数, eg. instanceof Array -
原型规则和示例
- 所有的引用类型(数组array、对象object、函数function)都具有对象(object)特性,即可自由扩展属性(除了null外);
- 所有的引用类型(数组array、对象object、函数function)都有一个__proto__(隐式原型)属性,属性值是一个普通的object.
- 所有的函数,都有一个prototype(显示原型)属性,属性值也是一个普通的对象。
- 所有的引用类型,proto(隐式原型)属性值指向它构造函数的prototype(显式原型)属性值
console.log(obj.__proto__===Object.prototype) //true,
- 当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么会它的__proto__(即它的构造函数的prototype)中寻找。
- 原型链
- instanceof
-用于判断引用类型属于哪个构造函数的方法f instanceof Foo// true
(判断逻辑:f的__proto__一层一层往上,能否对应到Foo.prototype, 再试着判断f instanceof Object)