问题贴:http://bbs.csdn.net/topics/390446362
new四部曲:
(1)创建一个新的对象,并让函数的 this 指针指向它;
(2)将函数的 prototype 对象的所有成员都赋给这个新对象,特别地:对象的__proto__ = 函数的prototype;
(3)执行函数体,对这个对象进行初始化操作;
(4)返回(1)中创建的对象
注意定义函数的时候这个函数是不会被执行的(个人比较容易搞错),在new时,先执行相关赋值,然后再执行构造函数。所以会出现第一次new后得到的对象没有继承指定的prototype的方法和属性(因为prototype还未重新赋值),第二次new就可以。看代码:
function View(){}
View.prototype.a = function{alert("我是View的父类函数");}
function switcher()
{switcher.prototype = View.prototype;
}
s = new switcher();
alert(s.a);
s = new switcher();
alert(s.a);
输出
那么要实现继承,解决办法是什么呢
方案一:
function View(){}
View.prototype.a = function{alert("我是View的父类函数");}
function switcher()
{
}
switcher.prototype = View.prototype; // 外部执行
s = new switcher();
alert(s.a);
s = new switcher();
alert(s.a);
输出:
方案二:
function switcher()
{this.__proto__ = View.prototype;
}
s = new switcher();
alert(s.a);
s = new switcher();
alert(s.a);
输出:
虽然两种方案效果一样,但是后者可以将语句放在函数内,这样更好,便于继承以及代码的耦合。