当前位置: 首页 > news >正文

西安网站制作公司排网站分析报告范文

西安网站制作公司排,网站分析报告范文,企业网站 实名认证,滁州市城乡建设委员会网站TypeScript 混入(Mixins) 混入(Mixins)是面向对象编程中的一个比较重要的概念。本节将会通过一个实例逐步介绍混入是如何在 TypeScript 中使用的。 1. 解释 在 TypeScript 中,可以根据不同的功能定义多个可复用的类,它们将作为 …

TypeScript 混入(Mixins)

混入(Mixins)是面向对象编程中的一个比较重要的概念。本节将会通过一个实例逐步介绍混入是如何在 TypeScript 中使用的。

1. 解释

在 TypeScript 中,可以根据不同的功能定义多个可复用的类,它们将作为 mixins。因为 extends 只支持继承一个父类,我们可以通过 implements 来连接多个 mixins,并且使用原型链连接子类的方法和父类的方法。

这就像组件拼合一样,由一堆细粒度的 mixins 快速搭建起一个功能强大的类。

2. 简单的对象混入

先来看一个基础例子:

let target = {  a: 1,  b: 1 }
let source1 = {  a: 2,  c: 3 }
let source2 = {  b: 2,  d: 4 }Object.assign(target, source1, source2)console.log(target) // { a: 2, b: 2, c: 3, d: 4 }

解释: 通过 Object.assign() 将 source1 与 source2 混入到 target 上,并且替换了 target 对象原有的属性值。

3. TypeScript Mixins

先介绍一个前置知识: Object.getOwnPropertyNames() 方法返回一个由指定对象的所有自身属性的属性名(包括不可枚举属性但不包括Symbol值作为名称的属性)组成的数组。

3.1 代码演示

下面的代码演示了如何在 TypeScript 中使用混入:

// Disposable Mixin
class Disposable {isDisposed!: booleandispose() {this.isDisposed = true}
}// Activatable Mixin
class Activatable {isActive!: boolean;activate() {this.isActive = true}deactivate() {this.isActive = false}
}class SmartObject{constructor() {setInterval(() => console.log(this.isActive + " : " + this.isDisposed), 500)}interact() {this.activate()}// DisposableisDisposed: boolean = falsedispose!: () => void// ActivatableisActive: boolean = falseactivate!: () => voiddeactivate!: () => void
}
applyMixins(SmartObject, [Disposable, Activatable])let smartObj = new SmartObject()
setTimeout(() => smartObj.interact(), 2000)function applyMixins(derivedCtor: any, baseCtors: any[]) {baseCtors.forEach(baseCtor => {Object.getOwnPropertyNames(baseCtor.prototype).forEach(name => {derivedCtor.prototype[name] = baseCtor.prototype[name]})})
}

3.2 逐步解析这个例子

代码里首先定义了两个类,它们将做为 mixins。可以看到每个类都只定义了一个特定的行为或功能。稍后我们使用它们来创建一个新类,同时具有这两种功能。

// Disposable Mixin
class Disposable {isDisposed!: booleandispose() {this.isDisposed = true}
}// Activatable Mixin
class Activatable {isActive!: booleanactivate() {this.isActive = true}deactivate() {this.isActive = false}
}

下面使用 implements 连接多个父类,需要在子类里实现所有接口定义。

class SmartObject implements Disposable, Activatable {}

这么做是为将要 mixin 进来的属性/方法创建出占位属性。这告诉编译器这些成员在运行时是可用的,这样就能使用 mixin 带来的便利,虽说需要提前定义一些占位属性。

  // DisposableisDisposed: boolean = falsedispose!: () => void// ActivatableisActive: boolean = falseactivate!: () => voiddeactivate!: () => void

子类对外暴露一个封装后的 public 方法,方法的具体实现可以借助混入的 mixins 类中的属性/方法:

  interact() {this.activate()}

最后,把 mixins 混入定义的类,完成全部实现部分。

applyMixins(SmartObject, [Disposable, Activatable])

applyMixins() 方法借助 Object.getOwnPropertyNames() 遍历 mixins 上的所有属性,并复制到目标上去,把之前的占位属性替换成真正的实现代码。

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

applyMixins() 这个工具函数可以封装在项目中一个核心函数库中。

4. 小结

混入这种思想在一些开源项目如 materialvue-class-component 中被广泛使用,我们日常工作中也可以根据需求借鉴使用。

http://www.hrbkazy.com/news/11301.html

相关文章:

  • 深圳做网站的公司那个好重庆seo职位
  • 做响应式网站的物流网站服务器怎么搭建
  • vue做的网站模板北海百度seo
  • 万网速成网站培训机构需要哪些证件
  • 敦煌做网站 条件网络营销的核心
  • 做短视频的能跟几个网站签约深圳百度推广开户
  • 子目录网站长沙seo外包优化
  • 北京建委网站证书查询精准营销推广
  • 网站移动端适配怎么做网络维护培训班
  • 网站建设资讯版块如何做用户运营北京seo推广公司
  • 怎样知道哪个网站做推广好今日头条极速版官网
  • 网站侵权怎么做公证或证据保存win7优化教程
  • 公司网站平台app渠道推广
  • 做好网站建设的重要性新手怎么做网络销售
  • 面包屑网站导航怎么做网络营销有哪几种方式
  • 做的最好的紫砂网站自己如何做一个网站
  • 汽车之家网页版跳极速版seo外链怎么发
  • 建设政府网站的必要性南京网站建设
  • 永济微网站建设费用湖南网络推广服务
  • 广东网站备案要求怎么创建网站快捷方式到桌面
  • 人才网网站方案青岛网站设计微动力
  • 杭州建网站企业百度客户端手机版
  • wordpress 生成js做优化关键词
  • 做啤酒行业的网站如何进行电子商务网站推广
  • 西安网站开发公司搜索引擎调价工具哪个好
  • thinkphp5网站开发北京百度快速排名
  • 做网站需要电脑吗新浪博客
  • 快云助手网站建设视频教程百度服务热线
  • 宁波靠谱的网站推广定制个人网页设计制作网站模板
  • 重生主角做视频网站的小说搜索引擎营销的方法包括