您的位置:首页 > Web前端

effective js-12-变量声明的提升(没有块级作用域)

2016-02-29 18:03 295 查看

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>js-没有块级作用域</title>

</head>

<body>

 

<script>

window.onload = function() {

   var a = 999;

   var c = 111;

   

   /**

* 此处正好说明,一个变量的块级作用域是不存在的,作用域是包含它的函数

*/

function test() {

       alert("test内部访问外部window.onload的c: " + c); // 111

       alert("此处说明了b变量声明的提升,b: " + b); // 如果没有声明的话,会报错 XXX is not defind.

   var a = 0;

   if(a == 0) {

       var b = 1; // b 变量声明的提升,跟 if 判断没关系,不管真假,都会提升,影响的是b的值

       var a = 3; // 是允许的

   }

   alert("test内部的a: " + a); // 3,test内部的a

   alert("此处说明了块级作用域是不存在的b: " + b); //1  如果块级作用域存在,则此处应该访问不到b

};

test();

 

alert("window.onload内部的a: " + a); // 999, onload内部的a

   

};

</script>

 

<p>

1. JS不支持块级作用域,也就是说,一个变量的作用域不是离它最近的封闭语句或代码块,而是包含它们的函数

详见本页的例子

</p>

 

</body>

</html>

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