爬坑:“experimentalDecorators“设置无效

报错:

error TS1219: Experimental support for decorators is a feature that is subject to change in a future release. Set the ‘experimentalDecorators’ option in your ‘tsconfig’ or ‘jsconfig’ to remove this warning.


原文:

1.gulpfile.js内容如下:

var gulp = require("gulp"),
    tsc = require("gulp-typescript"),
    typescript = require("typescript");

var tsProject = tsc.createProject({
    removeComments: false,
    noImplicitAny: false,
    target: "es5",
    module: "commonjs",
    declarationFiles: false,
    emitDecoratorMetadata: true,
    typescript: typescript
});

gulp.task("build-source", function () {
    return gulp.src(__dirname + "/file.ts")
    .pipe(tsc(tsProject))
    .js.pipe(gulp.dest(__dirname +"/"))
});

2.file.ts内容如下:

@logClass
class Person {
    
    public name: string;
    public surname: string;

    constructor(name: string, surname: string) {
        this.name = name;
        this.surname = surname;
    }

    public saySomething(something: string): string {
        return this.name + " " + this.surname + " says:" + something;
    }
}

function logClass(target: any) {
    var original = target;
    
    function construct(constructor, args) {
        var c: any = function() {
            return constructor.apply(this, args);
        }
        c.prototype = constructor.prototype;
        return new c();
    }

    var f:any = function(...args) {
        console.log("NEW: " + original.name);
        return construct(original, args);
    }

    f.prototype = original.prototype;

    return f;
}

解决方法:

gulpfile.js文件添加experimentalDecorators并设置为true.

var tsProject = tsc.createProject({
     ... ...
    experimentalDecorators: true,
});

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值