这篇文章主要介绍了 JavaScript 匿名函数之模仿块级作用域的相关资料, 需要的朋友可以参考下
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
匿名函数
函数是 JavaScript 中最灵活的一种对象,这里只是讲解其匿名函数的用途。
匿名函数:就是没有函数名的函数。
函数的定义,首先简单介绍一下函数的定义,大致可分为三种方式
第一种:这也是最常规的一种
- function double(x){
- return 2 * x;
- }
第二种:这种方法使用了 Function 构造函数,把参数列表和函数体都作为字符串,很不方便,不建议使用。
- var double = new Function('x', 'return 2 * x;');
第三种:
- var double = function(x) {
- return 2 * x;
- }
注意 "=" 右边的函数就是一个匿名函数,创造完毕函数后,又将该函数赋给了变量 square。
JavaScript 中是没有块级作用域概念的。也就是说,在块级语句中定义的变量,实际上是在包含函数中 (外部函数) 而非语句中创建的。
- function outputNumber(count){
- for(var i=0;i<1000;i++){
- alert(i);
- }
- alert(i); //count
- }
该函数在 java、C# 等语言中,变量 i 只会在 for 循环语句中有定义,循环结束,i 也就被销毁了。但在 JavaScript 中,变量 i 是定义在 outputNumber() 活动对象中的,因此在它定义开始,就可以在函数内部访问它。即使重新声明同一个变量,也不会改变它的值。
- function outputNumber(count){
- for(var i=0;i<1000;i++){
- alert(i);
- }
- var i; //重新声明变量
- alert(i); //count
- }
匿名函数可以用来模仿块级作用域并避免这个问题,用作块级作用域 (也称私有作用域) 的匿名函数的语法如下:
- (function(){
- //这是块级作用域
- })()
以上代码定义变调用了一个匿名函数,将函数声明包含在一个小括号里面,表示它是个函数表达式。紧跟其后的另一对小括号会立即调用这个函数。
无论什么时候,只要临时需要一些变量,就可以用私用作用域,例如:
- function outputNumber(count){
- (function(){
- for(var i=0;i<1000;i++){
- alert(i);
- })();
- alert(i); //导致一个错误
- }
这样,我们在 for 循环外部插入了一个私有作用域。在匿名函数中定义的任何变量,都会在执行结束时被销毁。
这种技术经常在全局作用域中被用在函数外部,从而限制向全局作用域中添加过多的变量和函数。
一般来说,我们应该尽量减少向全局作用域中添加变量和函数。
这种做法可以减少闭包占用内存的问题,因为没有指向匿名函数的引用,只要函数执行完毕,就可以立即销毁其作用域链。
来源: http://www.phperz.com/article/17/0215/268158.html