function po(){
/// this.age ="super age";
}
po.prototype.age ="super prototype age";
function func() {
//this.age='name has been changed.';
}
//func.prototype.age='prototype of func';
func.prototype = new po();
var f = new func();
alert(f.age); // 输出super prototype age
alert(func.prototype.age); // 输出super prototype age
这段代码会弹出两次super prototype age,原因如下:
对象寻找属性时,如果自己没有这个属性,会在构造函数的propotype所指向/引用的对象中找,看能否找到同名属性,如果构造函数的prototype没有还会找prototype对象的构造函数的prototype对象,
如果找到,就会读取它的值并返回.(这个过程会持续向上,直到持续到Object对象为止,即所谓原型方式的继承).
注意:以上是读,如果写一个属性的话就是直接给这个对象定义了一个属性,读写不对等,在<javascript权威指南>
有很好说明.
本贴内容来自于<领悟 JavaScript 中的面向对象>.
to robbin :
由于yiding_he写道"注:读完本文后请务必接着看完所有回复!"这样对于想要得到其中重要内容的读者来说太花时间了,所以我把几位网友(yiding_he,xieye,afcn0)的观点总结了一下,用于方便想要知道javaScript中的new的含义的新读者.也希望javaeye能够上一套wiki,方便大家对知识进行系统总结.论坛这种需要看完所有回帖才能得到知识的方式还是比不了wiki的方式.