日期:2014-05-16 浏览次数:20468 次
?
?
?
function Parent(name){
this.name = name || "default"; //赋予默认值
//return this;
}
var obj = new Parent();//var obj = Parent();
?
对象冒充,先把父构造函数变为子对象的一个方法,然后执行它,最后删除该函数
?
function Child(name,sex){
this.self = Parent; //self指向Parent所指向的地方
this.self(name); //初始化参数
delete this.self; //删除self
this.sex = sex || "M";
}
?
?
在子构造函数的内部用call()或者apply()方法传入this调用父构造函数
?
function Child(name,sex){
Parent.call(this,name);//Parent.apply(this,new Array(name));
this.sex=sex||"M";
}
?
?
在子构造函数声明后,把子构造函数的prototype赋值为父对象,缺点为不能传参初始化
?
function Child(name,sex){
this.sex = sex || "M";
}
Child.prototype = new Parent();
?
?
利用js的闭包特性实现私有属性和私有方法
?