javascript - js 中重写原型,不重定向原型中的 constructor 会有问题吗?
PHPz
PHPz 2017-04-11 10:16:17
[JavaScript讨论组]
function Person(name){
    this.name = name;
}

Person.prototype = {
    constructor: Person,
    say: function(){
        console.log(this.name);
    }
};

例如上面的代码,重写了 Person 原型之后如果不把 constructor 重定向,会有问题吗?在什么场景下会有问题?原型中的 constructor 属性有什么作用?

PHPz
PHPz

学习是最好的投资!

全部回复(4)
PHP中文网
var p1 = new Person("n");
// 之后,就可以通过
p1.constructor
// 获取 p1 的“构造函数”,也就是 Pserson

所以说,如果后面的东西没有利用这一属性就不会有什么问题,但是默认的原型里会有这个属性,那么保不齐某人或是某库会有这个东西,如果不写,那么对于此例来说,p1.constructor会得到Object,所以最好还是加上吧。

PHPz
Object.defineProperty(Person.prototype, 'constructor', {
  value: Person,
  writable: true,
  configurable: true,
  enumerable: false
});
怪我咯

倘若你在重写原型之前,用构造函数创建了实例,那么重写原型的话,之前创建的实例的原型将不是重写后的原型,所以不能继承重写后原型的属性和方法。

function Person(name){
    this.name = name;
}
var a = new Person('solarjoker');
Person.prototype = {
    constructor: Person,
    say: function(){
        console.log(this.name);
    }
};
a.say();//error
伊谢尔伦

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号