1、constructor(指向创建当前对象的构造函数)
// 【函数的constructor】
function Foo() {
console.log('Foo')
}
//===> Foo.constructor = Function() { [native code] } == Function
//===> Foo.prototype.constructor = Foo(){console.log('Foo')]
var foo1 = new Foo();
//===> foo1.constructor = Foo(){console.log('Foo')}
//===> foo1.__proto__.constructor = Foo(){console.log('Foo')}
-------------------------------------------------------------------
// ===>当构造函数的prototype重新赋值时,且不指定constructor的情况下,
// ===>其prototype.constructor默认为 Function(){}
//-----------【实例的constructor指向构造函数原型的constructor】-----------
foo1.constructor == Foo.prototype.constructor
2、prototype.constructor
// 每个函数都有一个prototype属性,且该属性值为一个对象,这个对象包含一个唯一不可枚举的属性,constructor。
// constructor的属性值是一个函数对象。
var F = function(){};
var p = F.prototype;
var c = p.constructor;
c === F; // ===> true 即 任意函数 F.prototype.constructor == F
// ----------------------------实例对象--------------------------------
var shili = new F();
shili.__proto__.constructor == F; // ==> true
3、原型 prototype(源自构造函数)__proto__(源自实例对象)
// 构造函数的原型 prototype 是共有的,实例化后的 对应实例的原型__proto__
// 即实例的__proto__都指向构造函数的 prototype
// 更改实例的 __proto__ 会影响其他实例以及构造函数的 prototype
// 同样,更改构造函数的prototype也会影响所有实例的__proto__