之前看过一段代码,大概是是这样:
function getVaildList(){ var _list = $(‘.list‘); _list.each(function(item){ var listContent = $(this); var listName = listContent.find(‘listName‘).text(); var aaa = aaa; var bbb = bbb; //假设还有很多 var ccc = ccc; . . . . . . . . . //dosomething }); return XXX; }
咋看一下也没啥毛病,程序也能跑起来,但是看着看着我就纠结起来了,如果变量数量很多呢?在循环中不断声明变量,这样好么?
仔细看上面的代码,其实我们不妨在函数的顶部先定义这些变量,这个的好处是什么呢?
在each的函数内部反复声明变量,变量在当前函数使用完之后就被内存释放,然后再次创建一个,这样循环下去,就会使得内存有不必要的损耗,我们完全可以延长变量的生命周期,在函数的顶部然后每次去改变它的值即可。
那么说到变量,就再说说局部变量和全局变量吧。
大家都知道,在浏览器中大量使用全部变量有可能会使得全局污染,所以最好的是实现一种模块功能,两个模块之间各自定义变量,互不影响,最后模块之间再引用就可以了。这不正是nodeJs所采用的函数式编程的思想么?那么node怎么做到这一点的呢?
其实node加载一个模块test.js之后,对所加载的模块改造一下:
(function(){
/***tese.js的内容
各种变量
***/
})()
这不是我们很熟悉的立即执行函数么?本来在test.js的全局函变量不就现在变成了函数内部的局部变量了吗?这样就不能污染外面的变量了,最后node再向外界暴露想暴露的变量。
其实在很多情况都使用了这用模式,比如单例模式等。
时间: 2024-10-10 04:05:41