在Typescript中的模块内创建get / set变量

时间:2013-03-14 15:58:07

标签: typescript

我想在模块中创建一个带有get / set属性的变量。 我看到了一些在类中创建get / set属性的工作示例,如下所示:

class MyClass {
    private view;
    get View() { return this.view; }
    set View(value) { this.view = value }
}

但我想在模块中做同样的事情:

module MyModule {
    export var view;
    //I want to create get/set methods for view property here
}

我该怎么做?

3 个答案:

答案 0 :(得分:11)

我认为这只是一种疏忽;我会向设计团队提出这个问题(我没有看到任何明显的原因,除了“我们还没有实现它”之外,它将被禁止)。解决缺乏一流语言支持的问题相当简单:

module Bar {
    var _qua = 42;

    declare export var qua: number;
    Object.defineProperty(Bar, 'qua', {
        get: function() { return _qua; },
        set: function(value) { _qua = value; }
    }); 
}

// Works
var x = Bar.qua;
console.log(x);
Bar.qua = 19;
console.log(Bar.qua);

答案 1 :(得分:5)

访问者仅适用于“成员”。成员只能成为课程的一部分,至少这是打字稿的方式。

访问器是在类原型上定义的,是模块没有的东西。如果你真的想要,你可以手动定义它,它确实有效。

module MyModule {
    var view;
    export var View;
    Object.defineProperty(MyModule, "View", {
        get: function () {
            console.log(1);
            return view;
        },
        set: function (val) {
            console.log(2, val);
            view = val;
        },
        enumerable: true,
        configurable: true
    });
}

MyModule.View = 555;
window["mm"] = MyModule.View;

正如所料,我得到了输出:

> 2 555
> 1

虽然我老实说不会:)

答案 2 :(得分:0)

您也可以将它包装在具有静态属性的类中:

module MyModule {
  export class MyClass {
    private static view;
    static get View() { return this.view; }
    static set View(value) { this.view = value }
  }
}