javascript类的模拟(对象、继承、私有属性、私有方法)
- 对象
- 在构造函(在调用函数时,若没有传递this对象,会在内部创建一个临时的this对象)数内部使用this关键字创建类的共有属性和方法,最后显示返回this对象,或者用new关键字隐式返回这个临时对象。
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的闭包特性实现私有属性和私有方法
相关推荐
nmgxzm00 2020-11-10
ifconfig 2020-10-14
hhanbj 2020-11-17
zfszhangyuan 2020-11-16
古叶峰 2020-11-16
一个智障 2020-11-15
jipengx 2020-11-12
81427005 2020-11-11
xixixi 2020-11-11
游走的豚鼠君 2020-11-10
苗疆三刀的随手记 2020-11-10
Web卓不凡 2020-11-03
小飞侠V 2020-11-02
帕尼尼 2020-10-30
爱读书的旅行者 2020-10-26
帕尼尼 2020-10-23
杏仁技术站 2020-10-23
淼寒儿 2020-10-22