我已经担任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类)有什么好处?为什么需要它们?
答案 0 :(得分:3)
好吧,使用闭包,您将无法回避属性的类型或应用Javascript的内置自省手段(instanceof
,isPrototypeOf
)。此外,闭包的自由变量与对象属性不同,因为它们在周围的范围内不可见。当然,您可以定义获取器和设置器来访问它们,但这有点尴尬,您仍然无法利用解构分配和语言的其他核心概念。
所以,是的,闭包和原型有一些共同的应用,即使它们并不完全正交,它们仍然是离散的概念。