日期:2014-05-16  浏览次数:20412 次

javascript继承机制__proto__与prototype

? 所有构造器(Function类)/函数都具有prototype属性,每个原型对象都会对应相应的__proto__,

普通字面量对象不包含prototype属性,但包含__proto__属性。

?

__proto__属性始终指向原型对象的prototype,如下:

	function Person(name, age){
	  this.name = name;
	  this.age = age;
	}

	Person.prototype.getName = function(){
	  return this.name;
	}

	Person.prototype.setName = function(name){
	  this.name = name;
	}

	var Man = {};
	Man.__proto__ = new Person("Jobs", 35);
	console.log(Man.getName());

	var Female = function(){};
	Female.prototype = new Person("Bill", 45);
	var female = new Female();
	console.log(female.getName());


	var Dog = {};
	Dog.__proto__.getName = function(){
		return "Docke";
	}

	console.log(Dog.getName());

总结补充:

若使用prototype属性 -> “类名.prototype”
若使用__proto__属性 -> “实例.__proto__”
它们两个其实是同一个东西。

通过实例得到类名的代码是“实例.counstructor”,即“实例.counstructor===类名”
因为 实例.__proto__===类名.prototype
而且 实例.counstructor===类名
所以 实例.__proto__===实例.counstructor.prototype
所以 __proto__是counstructor.prototype的缩写。

?