您的位置:首页 > Web前端 > JavaScript

JavaScript没有块级作用域

2016-10-22 11:25 423 查看
有些知识,不经常去碰,就会遗忘,在学习的过程中,经常做笔记,没事的时候回头看看也是种享受.
JavaScript没有块级作用域经常会造成理解上的困惑。在其他语言中,由花括号封闭的代码块都有自己的作用域(如果用ECMAScript的话来讲,就是它们自己的执行环境),因而支持根据条件来定义变量。
例如,如下的代码在JavaScript中并不会得到想象中的结果:
<script type="text/javascript">
//javascript没有块级作用域
if(true){
var color="blue";
}
alert(color);//弹出的值是 blue

for(var i=0;i<10;i++){
}
alert(i);//弹出的值是10

</script>
在JavaScript中:
 (1) if语句中的变量声明会将变量添加到当前的 执行环境(在这里是全局环境)中,如果再函数中,则添加到函数的局部环境中.
 (2) for语句创建的变量i,即使在for循环执行结束后,也依旧会存在于循环外部的执行环境中,如果再函数中,则添加到函数的局部环境中.

1、声明变量
   使用var声明的变量会自动添加到最接近的环境中。在函数内部,最接近的环境就是函数的局部环境;在with语句中,最接近的环境就是函数环境。如果初始化变量时没有使用var声明,该变量会自动添加到全局环境.
<script type="text/javascript">
function add(num1,num2){
var sum=num1+num2;
return sum;
}
var result=add(10,20); //30
alert(result);//30
alert(sum); //由于sum不是有效的变量,因此会导致错误
</script>
浏览器访问这个页面时,会弹出30,而后面的alert(sum)没有反应,F12打开浏览器控制台可以发现JS报错了,sum没有定义.



如果去掉sum去掉var的声明,则不会报错,因为改sum已添加到全局环境中了.

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: