原型

构造函数

var a = {}; 其实是 var a = new Object(); 的语法糖

var a = []; 其实是 var a = new Array(); 的语法糖

function Foo(){...}; 其实是 var Foo = new Function(...); 的语法糖

使用 instanceof 判断一个函数是否是一个变量的构造函数

注意:构造函数名以大写字母开头更规范。

五条原型规则

1.所有的引用类型(数组,对象,函数),都具有对象特性,即可自由扩展属性(除了null)。

2.所有的引用类型(数组,对象,函数),都有一个_proto_属性,属性值是一个普通的对象。

_proto_:隐式原型。

3.所有的函数,都有一个prototype属性,属性值也是一个普通对象。

prototype:显式原型。

4.所有的引用类型(数组,对象,函数),_proto_属性值 指向它的构造函数的“prototype”属性值。

指向:完全等于。

5.当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么会去它的_proto_(即它的构造函数prototype)中寻找。

this指向,循环对象自身的属性。

原型链

instanceof

用于判断引用类型属于哪个构造函数的方法。

Q:如何准确判断一个变量是数组类型?

A:使用instanceof Array ; typeof无法判断准确类型。

Q:写一个原型链继承的例子。

A:封装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 peri</p>').on('click', function() { alert('clicked'); }).html('<p>javascript</p>');

Q:描述 new 一个对象的过程。

A:创建一个新对象;this指向这个新对象;执行代码,即对this赋值;返回this。

function Foo(name, age) {
    this.name = name;
    this.age = age;
    //return this; 默认有这一行
}
var f = new Foo('zhangsan', 20)

Q:zepto(或其他框架)源码中如何使用原型链。

A:自己读吧。

Tips:读源码有技巧,先搜 相关源码解读分析 ,有技巧的去读。有源码阅读经历可以给简历加分,要说明阅读体会和收获,提升。zepto源码分析教程

原文地址:https://www.cnblogs.com/PeriHe/p/8111096.html