这是我在使用原型化构造函数时意外遇到的问题。下面是代码:
上面的代码[b]无法修改 Cons() 的原型对象[/b]!但是把 Cons.prototype.info="changed!" 这句放在建立实例之后,就有效了:
当时我就怀疑是不是在实例化 Cons() 之前,原型对象是无法访问的。不过很奇怪,可以在原型对象中建立新的属性:
这是怎么回事呢?从这个问题看,大家是如何理解 [b]prototype 创建[/b]、[b]访问[/b]和[b]销毁[/b]等问题的?
<script type="text/javascript">
function Cons(){ //声明构造函数 Cons()
Cons.prototype.info="something";
Cons.prototype.showInfo=function(){
alert(this.info);
}
}
Cons.prototype.info="changed!"; //尝试修改原型中的属性
var inst=new Cons(); //建立实例 inst
inst.showInfo(); //修改无效,警告"something"
</script>
上面的代码[b]无法修改 Cons() 的原型对象[/b]!但是把 Cons.prototype.info="changed!" 这句放在建立实例之后,就有效了:
//...
var inst=new Cons(); //建立实例 inst
Cons.prototype.info="changed!"; //尝试修改原型中的属性
inst.showInfo(); //警告"changed!"
//...
当时我就怀疑是不是在实例化 Cons() 之前,原型对象是无法访问的。不过很奇怪,可以在原型对象中建立新的属性:
<script type="text/javascript">
function Cons(){ //声明构造函数 Cons()
Cons.prototype.info="something";
Cons.prototype.showInfo=function(){
alert(this.info);
}
}
Cons.prototype.newInfo="new!"; //尝试在原型中添加属性
var inst=new Cons(); //建立实例 inst
alert(inst.newInfo); //有效,警告"new!"
</script>
这是怎么回事呢?从这个问题看,大家是如何理解 [b]prototype 创建[/b]、[b]访问[/b]和[b]销毁[/b]等问题的?