繁体   English   中英

打字稿和等效的js代码

[英]Typescript and equivalent js code

我从打字稿开始,遇到了约翰·帕帕(John Papa)的教程。 他有以下几点:

// TypeScript
class Car {  
    // Property (public by default)
    engine: string;

    // Constructor 
    // (accepts a value so you can initialize engine)
    constructor(engine: string) {
        this.engine = engine;
    }
}

等效的js代码:

// JavaScript
var Car = (function () {  
    function Car(engine) {
        this.engine = engine;
    }
    return Car;
})();

这让我感到困惑。 不应该是:

    function Car(engine) {
        this.engine = engine;
    }

我在这里想念什么吗?

没错,但是TypeScript代码看起来像是有原因的...

一旦向类中添加了一些方法,它就会变得更加明显:

class Car {  
    engine: Engine;
    constructor(engine: Engine) {
        this.engine = engine;
    }
    drive() { 
        this.engine.start();
    }
}

输出JS如下所示:

var Car = (function () {
    function Car(engine) {
        this.engine = engine;
    }
    Car.prototype.drive = function () {
        this.engine.start();
    };
    return Car;
}());

如您所见,TS使用IIFE来包装整个类声明。

这是将所有内容保持在一起的好方法。

使用装饰器的另一个示例:

@decorate
class Car {  
    engine: Engine;
    constructor(engine: Engine) {
        this.engine = engine;
    }
    drive() { 
        this.engine.start();
    }
}

并输出JS:

var Car = (function () {
    function Car(engine) {
        this.engine = engine;
    }
    Car.prototype.drive = function () {
        this.engine.start();
    };
    Car = __decorate([
        decorate
    ], Car);
    return Car;
}());

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM