新闻中心

J*aScript装饰器_类与方法修饰实践

2025-11-21
浏览次数:
返回列表
装饰器通过修改类或方法行为提升代码可维护性,如用LogCreation记录类创建时间,AddTimestamp添加实例属性,MeasureTime统计方法耗时,PreventConcurrent防止异步重复执行。

javascript装饰器_类与方法修饰实践

J*aScript 装饰器是一种特殊类型的声明,可以被附加到类、方法、访问器、属性或参数上,用来修改或增强它们的行为。虽然目前装饰器仍处于提案阶段(Stage 3),但在 TypeScript 和一些现代框架如 Angular、NestJS 中已被广泛使用。通过实际例子,我们可以更好地理解如何在类与方法中应用装饰器。

类装饰器:控制类的创建与行为

类装饰器接收构造函数作为唯一参数,可用于监视、拦截或替换类定义。

例如,我们想记录某个类的实例化时间:

function LogCreation(target: Function) {
  console.log(`${target.name} 类在 ${new Date().toISOString()} 被创建`);
}
<p>@LogCreation
class UserService {
getName() {
return "John Doe";
}
}
// 输出:UserService 类在 2025-04-05T10:00:00.000Z 被创建</p>

也可以返回一个新的构造函数来扩展原始类的功能:

function AddTimestamp<T extends { new (...args: any[]): {} }>(constructor: T) {
  return class extends constructor {
    createdAt = new Date();
  };
}
<p>@AddTimestamp
class Post {
title: string;
constructor(title: string) {
this.title = title;
}
}</p><p>const post = new Post("Hello World");
console.log(post.createdAt); // 输出当前时间
</font>

方法装饰器:监控与增强方法调用

方法装饰器应用于类的方法,接收三个参数:目标对象、成员名、成员的属性描述符。

常见用途包括日志记录、性能监控和权限检查。

比如添加一个耗时统计装饰器:

站长俱乐部购物系统 站长俱乐部购物系统

功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类

站长俱乐部购物系统 0 查看详情 站长俱乐部购物系统
function MeasureTime(target: any, propertyKey: string, descriptor: PropertyDescriptor) {
  const originalMethod = descriptor.value;
<p>descriptor.value = function (...args: any[]) {
console.time(propertyKey);
const result = originalMethod.apply(this, args);
console.timeEnd(propertyKey);
return result;
};</p><p>return descriptor;
}</p><p>class DataProcessor {
@MeasureTime
process(data: number[]) {
return data.map(x => x * 2).filter(x => x > 10);
}
}</p><p>const processor = new DataProcessor();
processor.process([1, 5, 6, 8, 12]); // 控制台输出类似:process: 0.2ms</p>

另一个实用场景是防止重复调用异步操作:

function PreventConcurrent(target: any, propertyKey: string, descriptor: PropertyDescriptor) {
  const originalMethod = descriptor.value;
  let isRunning = false;
<p>descriptor.value = async function (...args: any[]) {
if (isRunning) {
console.warn(<code>${propertyKey} 正在执行中,跳过本次调用</code>);
return;
}
isRunning = true;
try {
return await originalMethod.apply(this, args);
} finally {
isRunning = false;
}
};</p><p>return descriptor;
}</p>

属性装饰器与参数装饰器简要说明

属性装饰器用于监听属性的定义,常用于依赖注入系统。它接受两个参数:目标对象和属性名。

function InjectService(target: any, propertyKey: string) {
  target[propertyKey] = new SomeService(); // 模拟注入
}

参数装饰器则作用于方法参数,可用于元数据标记,例如:

function Validate(target: any, methodName: string, paramIndex: number) {
  Reflect.defineMetadata(`validate:${methodName}`, true, target.constructor);
}

这类功能通常结合 Reflect Metadata 实现更复杂的运行时类型系统。

基本上就这些核心实践。装饰器让代码更具声明性,把横切关注点(如日志、校验、缓存)从主逻辑中剥离。只要注意兼容性和性能影响,就能在项目中有效提升可维护性。

以上就是J*aScript装饰器_类与方法修饰实践的详细内容,更多请关注其它相关文章!


# 如何实现  # 江北区网站推广技巧优化  # 揭阳市seo推广报价  # 营销推广案例ppt教程  # 潍坊晓峰心理网站推广  # 天津智能网站建设推广  # 滨江企业网站优化服务  # seo都有哪些  # 长春求职网站建设文案  # 唐山网站建设排名公司  # 购物街网站建设海报  # 是一种  # 有何区别  # 上传文件  # javascript  # 多线程  # 程序设计  # 如何使用  # 管理器  # 自定义  # 购物系统  # 2025  # ai  # app  # typescript  # js  # java 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: Lar*el 8 多关键词数据库搜索优化实践  深入理解Go语言中的指针类型:以*string为例  MongoDB聚合管道:正确匹配对象数组中_id的方法  HTML空白字符处理机制:渲染、DOM与编码实践  小米14应用无法联网原因分析_小米14网络权限修复  从J*aScript对象中精确提取指定属性的教程  J*aScript中向JSON对象添加新属性的正确姿势  C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器  为什么简单的XML文件也会解析失败? 检查隐藏的非打印字符(如BOM)的方法  Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口  J*aScript教程:根据元素文本内容动态设置背景色  Node.js 中使用 node-cron 实现定时 API 数据抓取与处理  蛙漫官方正版入口 蛙漫网页在线全集免费观看  Yandex免登录官网入口_俄罗斯Yandex搜索引擎直达链接  C++如何实现一个装饰器模式_C++设计模式之动态地给对象添加额外职责  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  b站如何看历史记录_b站观看历史找回方法  MAC怎么在地图App里使用“四处看看”_MAC体验部分城市的3D实景街景  拼多多购物车商品数量无法修改如何处理 拼多多购物车操作优化方法  俄罗斯Yandex免登录入口_Yandex搜索引擎官网一键直达  如何优雅地解决Livewire文件上传难题?SpatieLivewireFilepond让一切变得简单  在J*a中如何使用Stream.map转换元素_Stream映射操作解析  Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换  抖音网页版怎么|直播|_抖音网页版开播操作指南  解决Django多数据库/多Schema环境下外键迁移问题  理解Python模块与全局变量的作用域管理  微博网页版怎么开启两步验证_微博网页版账号安全两步验证设置方法  快手官方唯一登录入口 谨防山寨钓鱼网站  微信网页版官方快速登录入口 微信网页版网页版账号直达  自定义Bag-of-Words实现:处理带负号的词汇权重  深入理解Go语言中Map值与方法接收器的交互:为什么需要临时变量  J*aScript中管理异步API调用:确保操作顺序与数据一致性  CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示  Kafka Streams中基于消息头条件过滤消息的实现指南  荣耀Play7T运行卡顿解决_荣耀Play7T性能优化  fishbowl官网免费版 fishbowl养鱼网站入口  解决深度学习模型训练初期异常高损失与完美验证准确率问题  晋江读书网页版在线登录 晋江读书电脑版官网  抖音网页版快捷访问 抖音网页版网页版入口操作教程  Golang如何优化CPU绑定任务分配策略_Golang CPU任务分配优化实践  Win11网速慢怎么解决 Win11网络设置优化解除限速  Windows10怎么开启夜间模式 Windows10系统设置调整色温与亮度缓解夜间用眼疲劳【教程】  4399网页游戏电脑版全新入口 4399电脑端在线玩指南  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  如何修改开机登录密码_Windows账户安全设置超详细教程【必学】  如何将HTML表格多行数据保存到Google Sheets  Linux如何排查内存不足OOME问题_LinuxOOM分析教程  Composer中的^和~符号代表什么_精通Composer版本号语义化约束  百度网盘网页版入口 百度网盘网页版官方登录网址  PHP中SSG-WSG API的AES加密实践:正确使用初始化向量 

搜索