模拟重载##
通过判断实际传入的参数的个数实现模拟重载
if(typeof args[0] === "object" && args[0])
// 当对象为null时,用typeof判断也是object,所以还要判断是否为空
调用子类方法实现继承##
调用基类(父类)的方法和属性
Person.call(this,name);
子类的方法覆盖了基类的方法,在子类中想用父类的初始化,就用Person.prototype.init.apply(this,arguments);
链实现式调用##
addclass函数里面return this;返回的是classmanager的实例。通过返回this实现链式调用
模拟抽象类##
想要子类去覆盖,但是不想被直接调用的方法,同样可以通过抛出异常的方式实现
在抽象类中抛出异常,防止抽象类直接被调用。
通过抛出异常,限制只能通过new调用
通过es5方法控制对象属性##
实现模块化##
容器探测器和link探测器###
两种方法:立即执行的匿名函数,返回对象;
构造器方法,通过设置this的值,默认返回this。
练习-实现探测器##
先实现原型链的继承,再扩展。
因为继承的时候会改写prototype属性,如果后继承可能会覆盖掉之前的prototype属性。
Object.freeze(obj);// ES5 冻结对象,不可删不可扩展也不可写。
整个探测器包含在一个立即执行匿名函数里,可以防止变量或函数声明泄露到外面
在功能上
1.先声明一个DetectorBase函数基类,带一个参数,作为其子类的参数接口。然后为该函数创建一个detect方法,由于DetectorBase不是一个具体的探测器,所以它的detect方法是没有意义的,但为了说明该类拥有该方法,可以直接抛出一个异常,作为一个抽象方法,避免被调用。
2.接着声明两个具体的探测器,并在其后建立与DetectorBase的继承关系,然后再为两个探测器创建各自的detect方法。
保护机制
1.将函数及其原型冰冻,防止增删属性及属性标签被修改
2.通过defineProperty将三个函数的属性标签设置为不可写、不可删除、不可枚举,达到既可以将函数暴露出来,又防止被修改、删除或枚举。