Javascript块级作用域

Javascript没有块级作用域的概念。这意味着在块级语句中定义的变量,实际上是在包含函数中而非语句中创建的。
eg:

function outputNumbers(count){
    for(var i=0;i<count;i++){
        alert(i);
    }
    alert(i);
}

在Javascript中,变量是定义在outputNumbers()的活动对象中的,因此从它由定义开始,就 可以在函数内部随处访问它。

用作块级作用域(通常称为私有作用域)的匿名阐述的语法如下所示:

function(){
    //这里是块级作用域
})();

以上代码定义并立即调用了一个匿名函数。将函数声明包含在一对圆括号中,表示它实际上是一个函数表达式。而紧随其后的另一对圆括号会立即调用这个函数。如果大家感觉这种语法不好理解,可以看看下面这个例子。

var someFunction=function(){
    //这里是块级作用域
};
someFunction();

因为变量只不过是值的另一种表现形式,因此用实际值替换变量是没有问题的。如下:

function(){
    //这里是块级作用域
}();//出错了!

这段代码会导致语法错误,是因为Javascript将function关键字当做一个函数声明的开始,而函数声明后面不能跟圆括号。然而,函数表达式的后面可以跟圆括号。要将函数声明转换为函数表达式,只要像下面这样给它加上一对圆括号即可。

(function(){
    //这里是块级作用域
})();

无论在什么地方,只要临时需要一些变量,就可以使用私有作用域,例如:

function outputNumbers(count){
    (function(){
        for(var i=0;i<count;i++){
            alert(i);
        }
    })();
    alert(i);//导致一个错误!
}

在这个方法中,我们在for循环外部插入了一个私有作用域。在匿名函数中定义的任何变量,都会在执行结束时销毁。因此,变量i只能在循环中使用,使用后即被销毁。

这种技术经常在全局作用域中被用在函数外部,从而限制向全局作用域中添加过多的变量和函数。一般来说,我们都应该尽量少向全局作用域中添加变量和函数。在一个由很多开发人员共同参与的大型应用程序中,过多的全局变量和函数很容易导致命名冲突。而通过创建私有作用域,每个开发人员既可使用自己的变量,又不必担心搞乱全局作用域。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值