首页 > js 中重写原型,不重定向原型中的 constructor 会有问题吗?

js 中重写原型,不重定向原型中的 constructor 会有问题吗?

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
});
【热门文章】
【热门文章】