function Person(name){
this.name = name;
}
Person.prototype = {
constructor: Person,
say: function(){
console.log(this.name);
}
};
例如上面的代码,重写了 Person 原型之后如果不把 constructor 重定向,会有问题吗?在什么场景下会有问题?原型中的 constructor 属性有什么作用?
constructor目前我只用它做过判断...
实例化对象的constructor指向创建它的构造函数
Person.prototype = {};
相当于Person.prototype = new Object();
此时创建Person.prototype这个实例化对象的构造函数是Object,所以
Person.prototype.constructor === Object; //true
有轻度强迫症的表示最好重定向回来,避免挖坑
如果怕忘记的话
Person.prototype.say = function(){
console.log(this.name);
};
避开重写Person.prototype
var p1 = new Person("n");
// 之后,就可以通过
p1.constructor
// 获取 p1 的“构造函数”,也就是 Pserson
所以说,如果后面的东西没有利用这一属性就不会有什么问题,但是默认的原型里会有这个属性,那么保不齐某人或是某库会有这个东西,如果不写,那么对于此例来说,p1.constructor
会得到Object
,所以最好还是加上吧。
倘若你在重写原型之前,用构造函数创建了实例,那么重写原型的话,之前创建的实例的原型将不是重写后的原型,所以不能继承重写后原型的属性和方法。
function Person(name){
this.name = name;
}
var a = new Person('solarjoker');
Person.prototype = {
constructor: Person,
say: function(){
console.log(this.name);
}
};
a.say();//error
Object.defineProperty(Person.prototype, 'constructor', {
value: Person,
writable: true,
configurable: true,
enumerable: false
});