Javascript块级作用域

怼烎@ 2022-05-31 09:17 287阅读 0赞

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

  1. function outputNumbers(count){
  2. for(var i=0;i<count;i++){ alert(i); }
  3. alert(i);
  4. }

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

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

  1. function(){
  2. //这里是块级作用域
  3. })();

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

  1. var someFunction=function(){
  2. //这里是块级作用域
  3. };
  4. someFunction();

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

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

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

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

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

  1. function outputNumbers(count){
  2. (function(){
  3. for(var i=0;i<count;i++){
  4. alert(i);
  5. }
  6. })();
  7. alert(i);//导致一个错误!
  8. }

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

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

发表评论

表情:
评论列表 (有 0 条评论,287人围观)

还没有评论,来说两句吧...

相关阅读

    相关 作用问题

    假设有五个按钮 利用for循环遍历这五个按钮 点击第i个按钮显示第i个按钮被点击 得到的结果却是:每次显示的都是遍历的最后第i个按钮 问题的原因:就在于for循环

    相关 JavaScript没有作用

    有些知识,不经常去碰,就会遗忘,在学习的过程中,经常做笔记,没事的时候回头看看也是种享受. JavaScript没有块级作用域经常会造成理解上的困惑。在其他语言中,由花括号封

    相关 Javascript作用

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