javascript - TypeScript 闭包——一个 "almost"的解决方案

标签 javascript typescript closures

我对 TypeScript 最大的疑虑之一是它会将所有方法(无论访问修饰符如何)都编译为原型(prototype)。

示例

class Example {
    public getString(): string {
        return "Hello World";
    }

    private getNumber(): number {
        return 123;
    }
}

正如我们所知,访问修饰符只在编译时检查,因此被发出的 JavaScript 忽略。 JavaScript 开发人员已经学会缓解这种情况的一种方法是使用闭包(好吧,我们知道闭包会带来性能损失,但我相信在某些情况下闭包是绝对必要的)。

示例

var Example = (function () {
    function Example() {
        this.getString = function () {
            return "Hello World";
        }

        var getNumber = function() {
            return 123;
        }
    }

    return Example;
})();

上面的例子尊重公共(public)/私有(private)访问。

我发现,通过使用 lambda 语法,我们可以在 TypeScript 中声明公共(public)闭包方法。

示例

class Example {
    getString = (): string => {
        return "Hello World";
    }
}

它不是特别漂亮,但它确实有效。

我想知道的是:我如何在 TypeScript 中声明私有(private)闭包?

示例

class Example {

    // TypeScript doesn't like this!
    var getNumber = (): number => {
        return 123;
    }
}

在此处查看有关此问题的更多信息:https://github.com/Microsoft/TypeScript/issues/2940

最佳答案

TypeScript 为 ES6 带来了类型和访问器(并且静态地检查两者)。 TypeScript 中的 class 关键字是 ES6 中的标准 class 关键字。 ES6 类中没有私有(private)闭包。此语法在 ES6 中无效:

class Example {
    var v = /* ... */; // invalid in ES6
}

如果你需要声明一个封装变量的闭包,你应该使用经典的 JavaScript 方式。我强烈建议利用 TS 接口(interface):

interface NamedObject {
    getName(): string;
}

let createNamedObject = function (name = 'John'): NamedObject {
    return {
        getName: function () {
            return name;
        }
    };
};

let obj: NamedObject = createNamedObject();

如果您真的想创建带有闭包的类方法,您可以这样做:

class BadPerformance {
    public getName: () => string;

    constructor(name = 'John') {
        this.getName = () => {
            return name;
        };
    }
}

关于javascript - TypeScript 闭包——一个 "almost"的解决方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30889214/

相关文章:

angular - 响应式(Reactive)表单自定义验证不适用于Blur、Angular 7

python - 嵌套函数中的局部变量

javascript - 如何绘制椭圆的一部分? (0-100%)

javascript - 返回具有参数传递的长度属性的数组

javascript - 我如何在 react 中只允许数字输入,例如,如果有人尝试复制粘贴文本

typescript - 在 Angular2 rc1 中基于路由隐藏元素

typescript - 如何设置通用约束以确保两种类型之间的公共(public)键也具有相同的值类型?

javascript - 将 javascript 闭包转换为柯里化(Currying)函数

javascript - 闭包中变量未定义?

javascript - 什么是 React 路由器中的内联渲染以及它如何与路由内的 "render"一起工作/