变量的作用域,是指变量的作用范围。也就是说,变量只在特定范围有效,超出该范围无效。
在JavaScript中,有两种变量,全局变量和局部变量:
- 全局变量:可以在脚本中的任何位置被调用,全局变量的作用域是当前文档中整个脚本区域。
- 局部变量:只能在此变量声明语句所属的函数内部使用,局部变量的作用域仅为该函数体。
声明变量时,要根据编程的目的决定将变量声明为全局变量还是局部变量。一般而言,保存全局信息(如用户信息、菜单选项等)的变量需声明为全局变量,而保存临时信息(如待输出的格式字符串、数学运算中间变量等)的变量则声明为局部变量。
举例说明变量作用域
【例2-1】考察如下代码:
- <html>
- <head>
- <title>局部变量和全局变量</title>
- </head>
- <body>
- <script type="text/javascript">
- var total=100; //全局变量
- function add(num){
- var total; // 局部变量
- total=2*num;
- return total;
- }
- </script>
- <p onclick="alert(add(100));">显示局部变量</p>
- <p onclick="alert(total);">显示全局变量</p>
- </body>
- </html>
保存并运行代码,点击第一段文本,显示 200;点击第二段文本,显示 100。
分析:点击第一段文本,运行add()函数,对total变量赋值。这时,JavaScript会寻找total变量,如果在函数内部找到,就赋值;找不到,就到函数外部寻找。显然,在函数内部已经找到,赋值后它的值为200。这里的total变量就是局部变量。
点击第二段文本,JavaScript会在全局内寻找total变量,如果找到,就返回它的值;找不到,将会引发错误。显然,已经找到,它的值是100。这里的total变量就是全局变量。
可以发现,在add()函数内部对total变量赋值,并未影响外部的total变量。
【例2-2】对【例2-1】稍作修改,去掉add()函数内部对total变量的声明。如下所示:
- <html>
- <head>
- <title>局部变量和全局变量</title>
- </head>
- <body>
- <script type="text/javascript">
- var total=100; //全局变量
- function add(num){
- total=2*num;
- return total;
- }
- </script>
- <p onclick="alert(add(100));">这已不是局部变量</p>
- <p onclick="alert(total);">显示全局变量</p>
- </body>
- </html>
保存并运行代码,点击两段文本,都显示 200 。
上述结果表明,JavaScript在add()函数内部没有找到total变量,又到函数外部寻找,找到后对它赋值,覆盖掉了原来的值。
说明:JavaScript是从小范围到大范围寻找变量的。如果在当前范围内没有找到相应的变量,就会一级一级向上级范围去寻找,找到后,就对它进行操作,找不到将会引发错误。
注意:任何情况下,JavaScript绝对不会从大范围向小范围寻找变量。如果在函数外部没有找到变量,绝对不会去函数内部寻找。
在函数内部声明全局变量
前面已经讲到,声明变量时要使用 var 关键字;但是,也可以不使用。
无论在函数外部还是内部,不使用 var 关键字声明的变量都为全局变量。
这就给我们提供了两种声明全局变量的方法:
- 在函数外部使用 var 关键字声明;
- 在任何地方不使用 var 关键字声明。
【例2-3】对【例2-2】稍作修改,去掉add()函数外部对total变量的声明。如下所示:
- <html>
- <head>
- <title>局部变量和全局变量</title>
- </head>
- <body>
- <script type="text/javascript">
- function add(num){
- total=2*num; // total 为全局变量
- return total;
- }
- </script>
- <p onclick="alert(add(100));">这已不是局部变量</p>
- <p onclick="alert(total);">显示全局变量</p>
- </body>
- </html>
保存并运行代码,点击两段文本,都显示 200 。
上述结果表明,在add()函数内部声明的total变量,已不再是局部变量,它在全局范围内都是有效的。
注意:
- 声明变量时请尽量使用 var 关键字,这对程序结构有很大的帮助。
- 尽量不要在函数内部声明全局变量,也不要在函数内部和外部声明同名变量,这两种情况都会造成变量的混淆。
只有在函数内使用 var 关键字声明的变量为局部变量
这里需要强调的是,只有在函数内部使用 var 关键字声明的变量才是局部变量,在其它“语句块”内使用 var 关键字声明变量一般是全局变量,if...else...选择结构和for循环结构都是如此。
【例2-4】在for循环内部声明变量。
- <html>
- <head>
- <title>在for循环内部声明变量</title>
- </head>
- <body>
- <script type="text/javascript">
- for(var i=0;i<=5;i++){
- var x=100;
- }
- </script>
- <p onclick="alert(i);">显示 i 变量的值</p>
- <p onclick="alert(x);">显示 x 变量的值</p>
- </body>
- </html>
点击第一段文本,显示 6 ;点击第二段文本,显示 100 。
上述结果表明,在for循环内部声明的 i 和 x 并不是局部变量,而是全局变量。
总结:除了函数,JavaScript是没有块级作用域的。