看到一个答案(原答案链接)说下面两种写法的意义截然不同。比较困惑这两种写法到底有什么不同,第一种写法看起来复杂一些,添加一个中间函数c的意义是什么?
第一种写法:
function a(){
var b = {};
function c(){
return b;
}
return c;
}
第二种写法:
function c(b){
return b;
}
第一种创建了一个闭包,即函数c可以访问其被声明时所处的上下文a中的变量b,同时在函数a外,无法访问到b,起到了私有变量的作用
比如:
function factory() {
var items = [1,2,3,4,5], i = 0;
return function() {
return items[i++];
}
}
var next = factory();
console.log(next()); // 1
console.log(next()); // 2
// 这里无法直接获取items
我再补充个有意思的:
function foo(){
var n = 0;
return function(){
n = n + 1;
return n * n;
}
}
var next = foo();
for(var i = 0;i<10;i++){
console.log(next());
}
// 1
// 4
// 9
// 16
// 25
// 36
// 49
// 64
// 81
// 100
用闭包实现柯里化
8 回答4.6k 阅读✓ 已解决
6 回答3.4k 阅读✓ 已解决
5 回答2.8k 阅读✓ 已解决
5 回答6.3k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
4 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
这个其实就是闭包的运用了。可以看看我刚总结的文章:闭包
你可以说他们没区别,因为它们实现的效果都相同;
你也可以说它们有区别,而且却别很大!因为它们实现的过程看起来会专业一些,用的好则提高代码质量和性能。具体来看下吧:
这种方式其实就是运用闭包实现的封装的形式,b成为了局部变量,减少了全局变量的污染,如果变量多的话,性能也是有提升的;如果你要修改b只能通过c方法,如果里面有其他重要数据,从而保证了数据的安全性!
但是这种方式也存在很大弊端,就是会引起内存泄漏:
这样的话,只要我不手动清除d的引用,则变量b会一直占据内存空间,直至浏览器关闭,这就引起了内存泄露了。当然如果你后面的代码不需要用到d了:
这样就解决内存泄露问题了。
至于第二种写法的,没有太大的问题,主要是封装性不够,就比如你要写一个轮播插件,那你可能就要在其他地方定义很多的方法和属性了。不方便管理维护,同时也增加了很多其他作用域内的变量。