gpt4 book ai didi

typescript 装饰器困惑

转载 作者:搜寻专家 更新时间:2023-10-30 21:12:58 26 4
gpt4 key购买 nike

我一直在玩 TypeScript 装饰器,但只是没有运气让它们工作。我读了How to implement a typescript decorator?还有http://blog.wolksoftware.com/decorators-reflection-javascript-typescript我从中创建了装饰器实现

function log(target: any, key: string, descriptor?: any) {

// save a reference to the original method
// this way we keep the values currently in the
// descriptor and don't overwrite what another
// decorator might have done to the descriptor.
if(descriptor === undefined) {
descriptor = Object.getOwnPropertyDescriptor(target, key);
}
var originalMethod = descriptor.value;

//editing the descriptor/value parameter
descriptor.value = function (...args: any[]) {
var a = args.map(a => JSON.stringify(a)).join();
// note usage of originalMethod here
var result = 12;//originalMethod.apply(this, args);
var r = JSON.stringify(result);
console.log(`Call: ${key}(${a}) => ${r}`);
return result;
}

// return edited descriptor as opposed to overwriting
// the descriptor by returning a new descriptor
return descriptor;
}

class C {
constructor(){
console.log("built");
}
@log
public foo(n: number) {
console.log("foo called");
return n * 2;
}
}
//new MethodDecoratorExample().method("hi");
var c = new C();
var r = c.foo(23); // "Call: foo(23) => 12"
console.log(r);

但是运行这段代码并没有产生我所期望的结果,事实上它似乎并没有覆盖描述符。深入挖掘,我发现在生成的代码中,对 __decorate 的调用只有三个参数

__decorate([
log
], C.prototype, "foo");

这意味着在 __decorate c = 3 中没有传入描述符。因此,新的描述符没有返回,代码流继续进行,就好像方法没有被拦截一样。

所以我一定是错误地应用了这个装饰器,但我看不出我是怎么弄错的。它可能被解释为属性描述符吗?我确实在某处看到了一些关于此的评论,但那是关于将 C 中的 foo 方法定义为 lambda,我没有这样做。

我怎样才能让它工作?

最佳答案

这里的问题是 TypeScript 默认会生成 ES3 代码,而方法 decorators generated for ES3显然与为 ES5 生成的那些工作方式有些不同。因此,除非您确实需要以 ES3 为目标,否则解决问题的简单方法是使用 tsc --experimentalDecorators --target es5 以 ES5 为目标,或者使用 tsc --experimentalDecorators --target 以 ES6 为目标es6.

关于 typescript 装饰器困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35108595/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com