现在的位置: 首页 > web前端 > 正文

JavaScript变量有几种?JavaScript有没有变量作用域

2020年06月15日 web前端 ⁄ 共 2194字 ⁄ 字号 评论关闭

  变量的作用域,是指变量的作用范围。也就是说,变量只在特定范围有效,超出该范围无效。下面学步园小编来讲解下JavaScript变量有几种?JavaScript有没有变量作用域?

  JavaScript变量有几种

  在JavaScript中,有两种变量,全局变量和局部变量:

  全局变量:可以在脚本中的任何位置被调用,全局变量的作用域是当前文档中整个脚本区域。

  局部变量:只能在此变量声明语句所属的函数内部使用,局部变量的作用域仅为该函数体。

  声明变量时,要根据编程的目的决定将变量声明为全局变量还是局部变量。一般而言,保存全局信息(如用户信息、菜单选项等)的变量需声明为全局变量,而保存临时信息(如待输出的格式字符串、数学运算中间变量等)的变量则声明为局部变量。

  JavaScript变量作用域有哪些

  点击第二段文本,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有没有变量作用域

  上述结果表明,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是没有块级作用域的。

  以上就是关于“JavaScript变量有几种?JavaScript有没有变量作用域”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.