博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Typescript Mixins(混合)
阅读量:7119 次
发布时间:2019-06-28

本文共 2461 字,大约阅读时间需要 8 分钟。

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

混合案例

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

// Disposable Mixinclass Disposable {    isDisposed: boolean;    dispose() {        this.isDisposed = true;    } } // Activatable Mixinclass 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 Mixinclass Disposable {    isDisposed: boolean;    dispose() {        this.isDisposed = true;    } } // Activatable Mixinclass Activatable {    isActive: boolean;    activate() {        this.isActive = true;    }    deactivate() {        this.isActive = false;    }}

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

class SmartObject implements Disposable, Activatable {

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

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

// DisposableisDisposed: boolean = false;dispose: () => void;// ActivatableisActive: 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];        })    }); }

转载地址:http://hniel.baihongyu.com/

你可能感兴趣的文章
工作了一个星期各位一定累了吧,那我们一起来表单验证一番吧!
查看>>
UVA 11732 - strcmp() Anyone?(Trie)
查看>>
java遍历hashMap、hashSet、Hashtable
查看>>
tcpdump
查看>>
如何注入值到Spring bean属性
查看>>
xm list源码分析
查看>>
PHPStorm 调式JS /同时调式PHP和jS
查看>>
JavaScript中的shift()、unshift()和pop()函数
查看>>
css案例学习之div与span的区别
查看>>
大话PHP缓存头
查看>>
【Java学习笔记之三十一】详解Java8 lambda表达式
查看>>
[zt]OpenCV2.1.0的安装
查看>>
Elasticsearch——Search的基本介绍
查看>>
Vue v-bind的使用
查看>>
第 22 章 Beta
查看>>
Linux 监视文件、文件夹改动
查看>>
[Erlang 0079] RabbitMQ 初探
查看>>
36.5. height / width
查看>>
树莓派蜜罐节点部署实战
查看>>
交换知识 VLAN VTP STP 单臂路由
查看>>