除了惯例的面对对象的思想,另一种较流行的通过可复用组件创建类的方法是将简单的类混合到一起。你可能对这种混合的方式比较熟悉或对Scala语言的特性有理解,这种模式在JavaScript社区也有一定的人气。

混合案例

在下面的代码中,我们展示了如何在TypeScript中混合模型,看完代码之后,再分析它的执行。

// Disposable Mixin
class Disposable {
isDisposed: boolean;
dispose() {
this.isDisposed = true;
} } // Activatable Mixin
class Activatable {
isActive: boolean;
activate() {
this.isActive = true;
}
deactivate() {
this.isActive = false;
}
} class SmartObject implements Disposable, Activatable {
constructor() {
setInterval(() => console.log(this.isActive + " : " + this.isDisposed), 500);
} interact() {
this.activate();
} // Disposable
isDisposed: boolean = false;
dispose: () => void;
// Activatable
isActive: boolean = false;
activate: () => void;
deactivate: () => void;
}
applyMixins(SmartObject, [Disposable, Activatable]) var smartObj = new SmartObject();
setTimeout(() => smartObj.interact(), 1000); ////////////////////////////////////////
// 在你代码的某处
//////////////////////////////////////// function applyMixins(derivedCtor: any, baseCtors: any[]) {
baseCtors.forEach(baseCtor => {
Object.getOwnPropertyNames(baseCtor.prototype).forEach(name => {
derivedCtor.prototype[name] = baseCtor.prototype[name];
})
});
}

理解案例

该代码例子刚开始的两个类是将被作为混合部分的类。你可以看到,每一类都有特定的功能。之后我们将这两个类混合成一个同时拥有这两个类的功能的新类。

// Disposable Mixin
class Disposable {
isDisposed: boolean;
dispose() {
this.isDisposed = true;
} } // Activatable Mixin
class Activatable {
isActive: boolean;
activate() {
this.isActive = true;
}
deactivate() {
this.isActive = false;
}
}

接下来,我们创建一个新的类,并将这两个类混合到这个新的类中。详细的看看它是如何做的:

class SmartObject implements Disposable, Activatable {

你可能会注意到的第一件事是我们使用了"implements",而不是"extends"。这样做是将类作为接口对待,只使用了"Disposable"和"Activatable"后面的类型,而不是实现这两个接口。这也意味着我们需要在类中实现这两个接口,但这恰恰是我们想通过混合来避免的问题。

为了满足这些需求,我们为这些将要混合进来的属性创建占位符和其类型。这样可以让编译器认识到这些成员在运行时是可用的。这么做能达到混合的利益,即使我们需要提前编写成员的占位符及其类型。

// Disposable
isDisposed: boolean = false;
dispose: () => void;
// Activatable
isActive: boolean = false;
activate: () => void;
deactivate: () => void;

最后,我们将这两个类混合进新的类,创建所有的实现方式。

applyMixins(SmartObject, [Disposable, Activatable])

最后,我们创建一个帮助我们做混合的辅助函数。这个函数遍历每个混合类上的每个属性,并且将他们拷贝到混合后的类中,填充在之前所留的占位符并且将其实现。

function applyMixins(derivedCtor: any, baseCtors: any[]) {
baseCtors.forEach(baseCtor => {
Object.getOwnPropertyNames(baseCtor.prototype).forEach(name => {
derivedCtor.prototype[name] = baseCtor.prototype[name];
})
});
}

最新文章

  1. 以前用SQL实现的机构职能树,再看看
  2. go环境import cycle not allowed问题处理
  3. dynamic获取类型可变的json对象
  4. 【Tree 3】树形结构数据加载的思考
  5. CentOS 6.3 安装 phpmyadmin
  6. 读取Jar包中的资源问题探究
  7. QQ上传大文件为什么这么快
  8. 酷摄影:关于梦 - Miki takahashi
  9. MVC引用CSS文件の正确姿势
  10. java中gson的简单使用
  11. VC++学习之网络编程中的套接字
  12. spring cloud微服务搭建第一天
  13. 开涛spring3(5.3) - Spring表达式语言 之 5.3 SpEL语法
  14. linux学习(二)linux配置网卡以及常见网络问题排查
  15. Fineui js getText
  16. saiku查询出错如何debug(saiku查询过程的本质),以及相关workbench的schema设置
  17. [经验交流] 试用基于 influxdb+kapacitor 的监控系统
  18. Why choose Nexiq USB-link 125032 Diesel Truck Diagnose
  19. Linux:CentOS 7系统的安装
  20. MongoDB的安装及安装为windows服务

热门文章

  1. Oracle 11g数据库详细安装步骤图解
  2. $.parseJson 在 firefox 下返回 null 的问题
  3. MySQL 更新语句技巧
  4. phpRedis安装、配置及简单使用
  5. 打开Application Data
  6. [已解决]从微软合作伙伴资源和MSDN下载系统和软件Microsoft download Manager无效
  7. C++STL - 模板的其他特性
  8. ubuntu 下安装 texlive 并设置 ctex 中文套装
  9. 架构实例之Demo_JSP
  10. C# Regex实例