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);
  };
};
相关推荐
一路往蓝-Anbo2 分钟前
C语言从句柄到对象 (八) —— 当对象会说话:观察者模式与事件链表
c语言·开发语言·数据结构·stm32·单片机·观察者模式·链表
GIOTTO情5 分钟前
舆情监测核心模块实战:从基础采集到智能优化
开发语言·python
可触的未来,发芽的智生9 分钟前
一万个为什么:频率和相位
javascript·人工智能·python·程序人生·自然语言处理
思成Codes10 分钟前
Golang并发编程——CSP模型
开发语言·后端·golang
csbysj202012 分钟前
Razor C# 循环
开发语言
gg1593572846016 分钟前
JavaScript 核心基础
前端·javascript·vue.js
蕨蕨学AI18 分钟前
【Wolfram语言】35 自然语言理解
开发语言·wolfram
Knight_AL19 分钟前
深入理解Java中的函数式接口
java·开发语言·python
Chen不旧20 分钟前
Java实现三个线程顺序打印
java·开发语言
charlie11451419122 分钟前
FreeRTOS: 信号量(Semaphores)、互斥量(Mutex)与优先级继承
开发语言·笔记·学习·c·freertos·实时操作系统