TypeScript方法装饰器应用

简介: TypeScript方法装饰器应用

背景


在初入安卓开发的阶段要为一个按钮绑定点击事件需要经过

  1. 通过ID查找视图
  2. 为视图添加监听方法
  3. 完成点击事件具体内容


后来引入了一些IOC的库使得第1步和第2步可以通过配置自动完成,我们只关心点击事件的具体逻辑处理即可。 在前端MVVM框架盛行的现在,我们的事件绑定已经相当的简单了,但还是会有时候用到传统的写法,我们通过改造传统的前端事件绑定的写法了了解一下TypeScript中方法装饰器的使用。


HTML中只有视图的声明
<button id="query">查询</button>
<button id="cancel">取消</button>
const queryNode = document.querySelector("#query");
queryNode?.addEventListener("click", function () {
  console.log("发起请求,查询数据~");
});

从上面的代码看的出前端的事件绑定和安卓中事件绑定的流程一致,都需要查找视图,添加监听方法,编写事件具体内容,重复的事情我们交给程序自动完成,专心写好查询函数。


引入接口来规范传入的参数


  • 参数1:绑定视图的ID
  • 参数2:绑定事件的名称
interface EventOptions {
  id: string;
  event: string;
}

创建方法装饰器


  1. 方法装饰器在运行时会当做函数传入以下三个参数来供我们使用
  • 参数1:原型对象
  • 参数2:成员名
  • 参数3:属性描述符


  1. 说明:


  • 装饰器函数中使用到了闭包
  • 通过参数1和2可以灵活定位函数
function bindEvent(options: EventOptions) {
  const { id, event } = options;
  return function (
    target: any, // ①原型对象
    propertyKey: string, // ②成员的名字
    descriptor: PropertyDescriptor // ③成员的属性描述符
  ) {
    const node = document.querySelector(`#${id}`);
    node?.addEventListener(event, function () {
      ④ 执行函数
      target[propertyKey]();
    });
  };
}


模拟类组件进行装饰

export class Component {
  @bindEvent({ id: "query", event: "click" })
  query() {
    console.log("发起请求,查询数据~");
  }
  @bindEvent({ id: "cancel", event: "click" })
  cancel() {
    console.log("接口取消~");
  }
}

现在就可以将视图的ID和待绑定的事件类型传入装饰器进行配置,我们就专心完成点击事件的具体功能吧。



相关文章
|
JavaScript 前端开发
TypeScript 定义同步方法
本文详细介绍了在TypeScript中定义同步方法的多种方式,包括使用类、接口、泛型和复杂的数据操作示例。通过理解这些方法,你可以在实际项目中有效地组织和管理你的代码,提高代码的可读性和维护性。
244 19
|
数据采集 JavaScript 前端开发
异步请求在TypeScript网络爬虫中的应用
异步请求在TypeScript网络爬虫中的应用
|
JavaScript 前端开发 安全
JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择
本文深入探讨了JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择。JavaScript以其灵活性和广泛的生态支持著称,而TypeScript通过引入静态类型系统,提高了代码的可靠性和可维护性,特别适合大型项目。文章还讨论了结合使用两种语言的优势,以及如何根据项目需求和技术背景做出最佳选择。
1842 4
|
机器学习/深度学习 人工智能 JavaScript
JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景
本文探讨了JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景。JavaScript将注重性能优化、跨平台开发、AI融合及WebAssembly整合;TypeScript则强调与框架整合、强类型检查、前端工程化及WebAssembly的深度结合。两者结合发展,特别是在Vue 3.0中完全采用TypeScript编写,预示着未来的Web开发将更加高效、可靠。
730 4
|
设计模式 JavaScript 安全
TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等
本文深入探讨了TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等,旨在帮助开发者在保证代码质量的同时,实现高效的性能优化,提升用户体验和项目稳定性。
473 6
|
JavaScript 安全 编译器
TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法
本文深入探讨了 TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法,并通过实际案例展示了其在项目中的应用效果,旨在提升代码质量和开发效率。
365 6
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
245 0
|
开发者 自然语言处理 存储
语言不再是壁垒:掌握 JSF 国际化技巧,轻松构建多语言支持的 Web 应用
【8月更文挑战第31天】JavaServer Faces (JSF) 框架提供了强大的国际化 (I18N) 和本地化 (L10N) 支持,使开发者能轻松添加多语言功能。本文通过具体案例展示如何在 JSF 应用中实现多语言支持,包括创建项目、配置语言资源文件 (`messages_xx.properties`)、设置 `web.xml`、编写 Managed Bean (`LanguageBean`) 处理语言选择,以及使用 Facelets 页面 (`index.xhtml`) 显示多语言消息。通过这些步骤,你将学会如何配置 JSF 环境、编写语言资源文件,并实现动态语言切换。
274 1
|
前端开发 JavaScript 安全
【前端开发新境界】React TypeScript融合之路:从零起步构建类型安全的React应用,全面提升代码质量和开发效率的实战指南!
【8月更文挑战第31天】《React TypeScript融合之路:类型安全的React应用开发》是一篇详细教程,介绍如何结合TypeScript提升React应用的可读性和健壮性。从环境搭建、基础语法到类型化组件、状态管理及Hooks使用,逐步展示TypeScript在复杂前端项目中的优势。适合各水平开发者学习,助力构建高质量应用。
445 0
|
JavaScript 安全 前端开发
TypeScript中的枚举类型有哪些应用场景
【8月更文挑战第4天】TypeScript中的枚举类型有哪些应用场景
405 5
下一篇
开通oss服务