日期:2014-05-16 浏览次数:20385 次
?
?
?
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的闭包特性实现私有属性和私有方法
?