ts装饰器保存this指向

要使用 function 而不是 箭头函数

typescript 复制代码
interface MethodDecorator<T> {
  (
    target: Object,
    propertyKey: string | symbol,
    descriptor: TypedPropertyDescriptor<T>
  ): TypedPropertyDescriptor<T> | void;
}

type TMethodDecorator = MethodDecorator<any>;

const matchImport: TMethodDecorator = (target, propertyKey, descriptor) => {
  const callback = descriptor.value;

  descriptor.value = function (...args: any[]) {
    console.log("decorator", this);
    return callback.call(this, ...args);
  };
};
相关推荐
前端一小卒4 分钟前
前端工程师的全栈焦虑,我用 60 天治好了
前端·javascript·后端
拾贰_C30 分钟前
【Google | Gemini | API | POST】怎么使用Google 的Gemini API (原生版)
开发语言·lua
t***5441 小时前
如何在Dev-C++中选择Clang编译器
开发语言·c++
橙子199110161 小时前
Java 基础相关
java·开发语言
coderyi1 小时前
LLM Agent 浅析
前端·javascript·人工智能
我叫黑大帅1 小时前
TypeScript 6.0 弃用选项错误 TS5101 解决方法
javascript·后端·面试
科雷软件测试1 小时前
使用python+Midscene.js AI驱动打造企业级WEB自动化解决方案
前端·javascript·python
星越华夏2 小时前
python——三角函数用法
开发语言·python
代码中介商2 小时前
C语言数据存储深度解析:从原码反码补码到浮点数存储
c语言·开发语言·内存