小编sim*_*eon的帖子

Typescript 中的装饰器返回函数的计时

用例:我想知道一个函数在打字稿中执行需要多长时间。我想使用装饰器来达到这个目的。我希望装饰器应该返回时间,以便(我可以进一步使用它),而不仅仅是打印它。
例如:

export function createTimestamps(message: string) {
  return function (target: any, name: string, descriptor: PropertyDescriptor) {
    const method = descriptor.value;
    descriptor.value = async function () {
      const startTime = new Date(Date.now());
      console.log(
        `${message} started at: ${startTime.toLocaleString("en-GB")}`
      );
      await method.apply(this);
      const endTime = new Date(Date.now());
      console.log(
        `${message} completed at: ${endTime.toLocaleString("en-GB")}`
      );
      console.log(
        `${message} took ${
          endTime.getTime() - startTime.getTime()
        }ms to complete.`
      );
    };
  };
}
Run Code Online (Sandbox Code Playgroud)

如果我使用上面的函数作为装饰器,那么我希望装饰器返回“endTime.getTime() - startTime.getTime()”,以便我可以进一步使用它。

@creaTimestamp
async newfunc():string{
 return "typescript";
}
Run Code Online (Sandbox Code Playgroud)

现在,当我调用上面的函数时,await newfunc()。我可以获取执行时间值以及它返回的字符串吗?

另外,我有很多函数,我想避免在每个函数之上添加装饰器,因此在调用它们时,我想确保装饰器运行并返回计时。有人可以指出我这样的图书馆(如果存在)吗?

有人可以分享一些对上述场景的见解吗,我对装饰器很陌生。谢谢!

typescript javascript-decorators

2
推荐指数
1
解决办法
2539
查看次数

标签 统计

javascript-decorators ×1

typescript ×1