当我们有闭包时,JavaScript是否需要原型?

时间:2018-11-21 07:58:47

标签: javascript class closures prototype

我已经担任Web开发人员三年了。我很少为对象创建自己的原型(我想我也通过新的ES 6类语法创建了原型)。

只要我可以使用原型做些什么:

function Client(host, port) {
    this.host = host;
    this.port = port;
}

Client.prototype.httpRequestHelper = function(body) {
    ...
};

var client = new Client('http://127.0.0.1', 8801);

使用闭包效果很好,并且是首选方法,因为更多的人很好地理解了该方法(包括我在内):

function createClient(host, port) {
    function httpRequestHelper(body) {
        ...
    }

    return {
        httpRequestHelper
    }
}

var client = createClient('http://127.0.0.1', 8801);

相比于闭包,使用原型(和ES6类)有什么好处?为什么需要它们?

1 个答案:

答案 0 :(得分:3)

好吧,使用闭包,您将无法回避属性的类型或应用Javascript的内置自省手段(instanceofisPrototypeOf)。此外,闭包的自由变量与对象属性不同,因为它们在周围的范围内不可见。当然,您可以定义获取器和设置器来访问它们,但这有点尴尬,您仍然无法利用解构分配和语言的其他核心概念。

所以,是的,闭包和原型有一些共同的应用,即使它们并不完全正交,它们仍然是离散的概念。