从TypeScript中的类中派生接口

更新日期: 2019-07-24阅读: 1.9k标签: 接口

大多数面向对象编程语言都鼓励编程到接口的模式。 TypeScript 当然支持这一点,你可以创建一个或多个接口,然后再定义生成这个接口实例的类(或工厂)。

但是当程序员预期将来可能会存在多个具体实现时,有时会过度使用对接口的编程,尽管在实现时可能有一个。

在直到真正实际需要这些多个实现之前,这些单实现接口会继续增加维护开销,因为每次我们需要引入新成员时,都需要修改两个位置。当然可以依靠工具来帮忙,但它仍然不是理想的解决方式。

此外,仅依靠具体实现并不是理想的解决方案,因为如果我们将来需要多个实现的话,TypeScript 编译器服务还没有一个很好的机制能够批量替换具体实现的所有用法与相对应的接口。

因此在本文中,我们探索了 typescript 的两个功能,可以帮助我们解决这个问题。


从类派生接口

TypeScript 的一个鲜为人知的特性是接口可以从类派生。

export interface SyncBackend extends FSSyncBackend {}

这对我们的用例来说似乎是一个明智的选择。但是有一个重要的警告:实现的所有私有或受保护成员都将会在派生接口中公开。

如果你对此感到惊讶,你并不孤独。当我第一次遇到它时,发现它非常反直觉,但在官方文档中解释了其背后的基本原理:

当接口类型扩展类的类型时,它继承类的成员但不继承它们的实现。就好像接口已经声明了类的所有成员而没有提供实现一样。接口甚至会继承基类的私有成员和受保护成员。这意味着当你创建一个继承了具有私有或受保护成员的类的接口时,该接口类型只能由该类或其子类实现。

当你具有大型继承层次结构但希望指定你的代码仅使用具有某些属性的子类时,这非常有用。除了继承基类之外,子类不必相关。

所以,这一切都很好,但如果我们只想要公有成员,应该怎么办?值得庆幸的是存在一个简单的解决方法


使用映射类型

我们可以使用从类型的公共成员派生的映射类型

由于类定义是隐式的类型定义,因此这也适用于类:

export type SyncBackend = { 
    [K in keyof FSSyncBackend]: FSSyncBackend[K];
}

现在 SyncBackend 类型只有 FSSyncBackend 类的公共成员。

虽然在大多数情况下,这达到了我们的目的,但如果我们严格需要一个接口而不是一个别名(可能是为了改进类型错误消息),可以简单地定义一个从这个别名扩展的接口:

type SyncBackend$1 = { 
    [K in keyof FSSyncBackend]: FSSyncBackend[K];
}

export interface SyncBackend extends SyncBackend$1 {}

如果最终我们确实需要多个实现,可以选择具有明确定义的接口,或者将一个实现保留为规范实现,从中派生接口并使其他实现符合该规范。

如果实际暴露了多个实现,则前一个解决方案(显式定义的接口)有助于将接口的 api 记录与各个实现的记录分开。

原文:https://lorefnon.tech/2019/08/18/deriving-interfaces-from-classes-in-typescript/

链接: https://www.fly63.com/article/detial/4908

为什么前后端分离了,你比从前更痛苦?

前后端分离可以让我们的职责更清晰,打破前端发挥的局限,工作解耦之后能更好的提高开发效率。然而因为没有规划好开发流程,导致了我们没有发挥出其应有的价值,造成了更多的浪费。

前后端分离项目的跨域及保持Session会话

当Web项目前后端分离开发的时候, 由于域名不一致, 会出现无法请求和无法维持会话的情况,在前端Ajax请求后台的时候, 打开控制台可以看到, 每一次请求之前都会有一次OPTIONS类型的请求

PHP面向对象(抽象类与抽象方法、接口的实现)

任何一个类,如果它里面至少有一个方法是被声明为抽象的,那么这个类就必须被声明为抽象的。定义为抽象的类不能被实例化。 被定义为抽象的方法只是声明了其调用方式(参数),不能定义其具体的功能实现。

vue 项目接口管理

在vue开发中,会涉及到很多接口的处理,当项目足够大时,就需要定义规范统一的接口,如何定义呢?方法可能不只一种,本文使用axios+async/await进行接口的统一管理。

免费的公共API接口_WebService接口大全

这篇文章为大家整理一下免费,常用的的WebService接口,列举一些搜集到的免费的公共API接口,希望对你有所帮助,天气预报Web服务,数据来源于中国气象局;IP地址来源搜索 WEB 服务;随机英文、数字和中文简体字

常用HTTP接口测试工具对比

从功能上Jmeter最为强大,可以测试各种类型的接口,不支持的也可以通过网上或自己编写的插件进行扩展。SoapUI专门针对HTTP类型的两种接口,其初衷更是专门测试Soap类型接口,对于其他协议的接口不支持

TypeScript接口(Interfaces)来定义对象的类型

在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型。在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类(classes)去实现(implements)

你不得不了解的前后端分离原理!

前后端分离已成为互联网项目开发的业界标准使用方式,通过nginx+tomcat的方式(也可以中间加一个nodejs)有效的进行解耦,并且前后端分离会为以后的大型分布式架构、弹性计算架构

vue项目接入mock&& axios 通用配置

兵马未动,粮草先行; 同理,项目开发过程中经常会出现接口未出, 前端页面已搭建完毕的情况;此时为了提高前端的开发效率,解放生产力,我们 FE 可以按照预定的接口文档做一些接口模拟的工作

vue中使用proxy配置不同端口和ip接口

使用vue-cli创建的项目,开发地址是localhost:8080,由于后台开发不同的模块,导致每个模块请求的ip和端口号不一致,解决问题:在vue.config.js中配置不同的端口号

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!