TypeScript 5.0 中的装饰器:优雅地修改类和方法
本文节选自《释放TypeScript的威力》,将向您展示如何在TypeScript 5.0中使用装饰器这一新特性。
装饰器几乎一直是ECMAScript的一部分。这些简洁的工具允许我们以可重用的方式修改类和成员。它们在TypeScript中已经存在一段时间了——尽管是在实验性标志下。虽然装饰器的Stage 2迭代一直是实验性的,但它们已被广泛应用于MobX、Angular、Nest和TypeORM等库中。TypeScript 5.0的装饰器与ECMAScript提案完全同步,已经非常成熟,处于Stage 3阶段。
装饰器允许我们创建一个函数,该函数可以调整类及其方法的行为。假设我们需要在方法中添加一些调试语句。在TypeScript 5.0之前,我们只能手动在每个方法中复制粘贴调试语句。使用装饰器,我们只需操作一次,更改就会应用于装饰器附加的每个方法。
让我们创建一个用于记录给定方法已弃用的装饰器:
class Card { constructor(public suit: Suit, public rank: Rank) { this.suit = suit; this.rank = rank; } get name(): CardName { return `${this.rank} of ${this.suit}`; } @deprecated // ? 这是一个装饰器! getValue(): number { if (this.rank === 'Ace') return 14; if (this.rank === 'King') return 13; if (this.rank === 'Queen') return 12; if (this.rank === 'Jack') return 11; return this.rank; } // 新的实现方式! get value(): number { if (this.rank === 'Ace') return 14; if (this.rank === 'King') return 13; if (this.rank === 'Queen') return 12; if (this.rank === 'Jack') return 11; return this.rank; } } const card = new Card('Spades', 'Queen'); card.getValue();
我们希望每当调用card.getValue()时,都会向控制台记录一条警告消息。我们可以如下实现上述装饰器:
const deprecated = <This, Arguments extends any[], ReturnValue>( target: (this: This, ...args: Arguments) => ReturnValue, context: ClassMethodDecoratorContext<ReturnValue> ) => { const methodName = String(context.name); function replacementMethod(this: This, ...args: Arguments): ReturnValue { console.warn(`Warning: '${methodName}' is deprecated.`); return target.call(this, ...args); } return replacementMethod; };
乍一看这可能有点令人困惑,但让我们分解一下:
- 我们的装饰器函数接受两个参数:target和context。
- target是我们正在装饰的方法本身。
- context是关于该方法的元数据。
- 我们返回一个具有相同签名的函数。
- 在这种情况下,我们调用console.warn来记录弃用通知,然后调用该方法。
ClassMethodDecorator类型具有以下属性:
- kind:被装饰属性的类型。在上面的示例中,这将是method,因为我们正在装饰Card实例上的方法。
- name:属性的名称。在上面的示例中,这是getValue。
- static:一个值,指示类元素是静态(true)还是实例(false)元素。
- private:一个值,指示类元素是否具有私有名称。
- access:一个对象,可以在运行时用于访问类元素的当前值。
- has:确定对象是否具有与被装饰元素同名的属性。
- get:在提供的对象上调用setter。
您可以在此playground中测试上面的代码示例。
装饰器为添加日志消息(如我们在上面的示例中所做的那样)以及许多其他常见用例提供了方便的语法糖。例如,我们可以创建一个装饰器,该装饰器会自动将方法绑定到当前实例,或者修改方法或类的属性描述符。
本文节选自《释放TypeScript的威力》,可在SitePoint Premium和电子书零售商处购买。
以上是快速提示:打字稿中的装饰器的详细内容。更多信息请关注PHP中文网其他相关文章!

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)