学习JS笔记(第九章-OOP下)

模拟重载##

通过判断实际传入的参数的个数实现模拟重载
if(typeof args[0] === "object" && args[0])// 当对象为null时,用typeof判断也是object,所以还要判断是否为空

学习JS笔记(第九章-OOP下)_第1张图片
Paste_Image.png

调用子类方法实现继承##

调用基类(父类)的方法和属性Person.call(this,name);
子类的方法覆盖了基类的方法,在子类中想用父类的初始化,就用Person.prototype.init.apply(this,arguments);

学习JS笔记(第九章-OOP下)_第2张图片
Paste_Image.png

链实现式调用##

addclass函数里面return this;返回的是classmanager的实例。通过返回this实现链式调用

学习JS笔记(第九章-OOP下)_第3张图片

模拟抽象类##

想要子类去覆盖,但是不想被直接调用的方法,同样可以通过抛出异常的方式实现

在抽象类中抛出异常,防止抽象类直接被调用。
通过抛出异常,限制只能通过new调用

学习JS笔记(第九章-OOP下)_第4张图片
Paste_Image.png

通过es5方法控制对象属性##

Paste_Image.png
学习JS笔记(第九章-OOP下)_第5张图片
Paste_Image.png

实现模块化##

容器探测器和link探测器###

两种方法:立即执行的匿名函数,返回对象;
构造器方法,通过设置this的值,默认返回this。

学习JS笔记(第九章-OOP下)_第6张图片
Paste_Image.png

练习-实现探测器##

先实现原型链的继承,再扩展。
因为继承的时候会改写prototype属性,如果后继承可能会覆盖掉之前的prototype属性。
Object.freeze(obj);// ES5 冻结对象,不可删不可扩展也不可写。

整个探测器包含在一个立即执行匿名函数里,可以防止变量或函数声明泄露到外面

在功能上
1.先声明一个DetectorBase函数基类,带一个参数,作为其子类的参数接口。然后为该函数创建一个detect方法,由于DetectorBase不是一个具体的探测器,所以它的detect方法是没有意义的,但为了说明该类拥有该方法,可以直接抛出一个异常,作为一个抽象方法,避免被调用。
2.接着声明两个具体的探测器,并在其后建立与DetectorBase的继承关系,然后再为两个探测器创建各自的detect方法。

保护机制
1.将函数及其原型冰冻,防止增删属性及属性标签被修改
2.通过defineProperty将三个函数的属性标签设置为不可写、不可删除、不可枚举,达到既可以将函数暴露出来,又防止被修改、删除或枚举。

学习JS笔记(第九章-OOP下)_第7张图片
Paste_Image.png
学习JS笔记(第九章-OOP下)_第8张图片
Paste_Image.png

你可能感兴趣的:(学习JS笔记(第九章-OOP下))