码迷,mamicode.com
首页 > 编程语言 > 详细

javascript --- 原型初探七日谈(三)

时间:2016-08-30 00:23:06      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:

原型陷阱:

在处理原型问题上时,我们要注意两种行为。

  1. 当我们对原型对象执行完全替换的时候,有可能会触发原型链的某种异常。

  2. prototype.constructor 属性是不可靠的。

下面,我们新建一个构造函数,并创建两个对象:

var her = fucntion(){
    this.name = ‘Anna‘;
}
var she1 = her();
var she2 = her();

即使在对象she1和she2对象被创建之后,我们仍然可以对her()的原型添加属性,并且之前创建的这些对象也可以访问这些属性。

her.prototype.say = function(){
    return ‘Hello‘
}
she1.say(); // Hello
she2.say(); // Hello

如果我们检查一下这些对象的构造函数,会发现一切正常:

she1.constructor === her;  // true
she2.constructor === her;  // true

现在,我们用一个新对象覆盖掉该构造函数的原型对象:

her.prototype = {
    sex : ‘women‘,
    height : ‘170cm‘
}

事实证明,原有对象不能访问这些新增属性了,但原有对象们与她们的构造函数还保持着一种神秘的联系:

she1.sex; // undefined
she1.say(); // Hello

而我们之后创建的对象使用的或访问的都是更新过后的prototype对象。

var a = her();
a.say(); // a.say() is not defined;
a.sex = ‘women‘;

这时候,新对象的constructor就不会在指向her()了,而是指向Object().

a.constructor;  // function Object(){}
she1.constructor; // function her(){this.name = ‘Anna‘}

 当然我们可以设置constructor属性的指向来解决上述异常:

function her(){};
her.prototype = {};
new her().constructor === her;  // false
her.prototype.constructor = her;
new her().constructor === her; // true

 

当我们重写prototype对象的时候,一定要重置prototype的constructor属性。

技术分享  就是辣么酸爽

javascript --- 原型初探七日谈(三)

标签:

原文地址:http://www.cnblogs.com/beyond-succeed/p/5820119.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!