jQuery 源码理解的基础

/**
* Created by cyk on 14-4-17.
*/
function Person() {
var temp = this; //this指向Person
console.log("here");
return new Person.prototype.init();
}

Person.prototype = {
constructor: Person, //这种方式覆盖了Person的prototype,所以要重新指定constructor
init: function () {
// var temp = this; //因为init是构造函数,第6行被new了,被new的时候构产生的对象会调用构造方法,谁调指向谁,this指向新建对象

//this与prototype无关,这是构造函数的内部问题,构造函数中的this指向新创建的对象,
// 而对象有自己的执行环境,即新对象的执行环境在init方法内部,
// 新创建的对象中有prototype下的方法,
//so,jQuery源码入门的难点理解了
console.log(this);
// console.log(this instanceof Person); //this == Person.init 这种语句没有任何意义,this是新建造的对象,而后者是一个方法的引用
// return new Date();
}
}

//Person.prototype.init.prototype 表示12行的构造函数下要有Person.prototype下面的这些方法
Person.prototype.init.prototype = Person.prototype;

var person1 = new Person();
var person2 = new Person();

console.log(person1 == person2)

console.log(person1)

原文地址:https://www.cnblogs.com/yakun/p/3673479.html