刚开始学js,遇到了一个奇怪的问题,查找之后知道了答案

需要记住两句话

1 Javascript的变量的scope是根据方法块来划分的(也就是说以function的一对大括号{ }来划分)。切记,是function块,而for、while、if块并不是作用域的划分标准

2 Javascript在执行前会对整个脚本文件的定义部分做完整分析(包括局部变量),从而确定实变量的作用域

示例

1 下面这段代码输出的是undefined 10

  1. <script type="text/javascript">
  2. var a =10;
  3. (function () {
  4. console.log(a);
  5. var a=20;
  6. })();
  7. console.log(a);
  8. </script>

  function中有了 var a=20;的定义,便会覆盖全局a的定义,所以console.log(a);的值是undefined

  出了函数后,局部a失效,所以会输出 10

2 将函数中 var a=20; 的定义去掉后,输出是10 10

  1. <script type="text/javascript">
  2. var a =10;
  3. (function () {
  4. console.log(a);
  5. })();
  6. console.log(a);
  7. </script>

  没有全局定义所以输出是 10 10

3 下面这段代码的输出是 undefined 20 10

  1. <script type="text/javascript">
  2. var a =10;
  3. (function () {
  4. console.log(a);
  5. var a=20;
  6. console.log(a);
  7. })();
  8. console.log(a);
  9. </script>

  

4 下面这段代码的输出是10 20 20

  1. <script type="text/javascript">
  2. var a =10;
  3. (function () {
  4. console.log(a);
  5. a=20;
  6. console.log(a);
  7. })();
  8. console.log(a);
  9. </script>

5 下面这段代码的输出是 undifined 20 10

  1. <script type="text/javascript">
  2. var a =10;
  3. (function () {
  4. console.log(a);
  5. a=20;
  6. var a;
  7. console.log(a);
  8. })();
  9. console.log(a);
  10. </script>

  函数中虽然 赋值语句 a=20; 在声明语句之前,但 var a; 依然会被赋值 所以输出  undifined 20 10

再来一个示例

  1. <script>
  2. function test2(){
  3. alert ("before for scope:"+i); // i未赋值(并不是未声明!使用未声明的变量或函数全抛出致命错误而中断脚本执行)
  4.  
  5. // 此时i的值是underfined
  6. for(var i=0;i<3;i++){
  7. alert("in for scope:"+i); // i的值是 0、1、2, 当i为3时跳出循环
  8. }
  9. alert("after for scope:"+i); // i的值是3,注意,此时已经在for scope以外,但i的值仍然保留为3
  10.  
  11. while(true){
  12. var j = 1;
  13. break;
  14. }
  15. alert(j); // j的值是1,注意,此时已经在while scope以外,但j的值仍然保留为1
  16.  
  17. if(true){
  18. var k = 1;
  19. }
  20. alert(k); //k的值是1,注意,此时已经在if scope以外,但k的值仍然保留为1
  21. }
  22.  
  23. test2();
  24. //若在此时(function scope之外)再输出只存在于test2 这个function scope里的 i、j、k变量会发生神马效果呢?
  25. alert(i); //error! 没错,是error,原因是变量i未声明(并不是未赋值,区分test2函数的第一行输出),导致脚本错误,程序到此结束!
  26. alert("这行打印还会输出吗?"); //未执行
  27. alert(j); //未执行
  28. alert(k); //未执行
  29. </script>
  1. <script>
  2. var a =1;
  3. function test(){
  4. alert(a); //a为undefined! 这个a并不是全局变量,这是因为在function scope里已经声明了(函数体倒数第4行)一个重名的局部变量,
  5. //所以全局变量a被覆盖了,这说明了Javascript在执行前会对整个脚本文件的定义部分做完整分析,所以在函数test()执行前,
  6. //函数体中的变量a就被指向内部的局部变量.而不是指向外部的全局变量. 但这时a只有声明,还没赋值,所以输出undefined。
  7. a=4
  8. alert(a); //a为4,没悬念了吧? 这里的a还是局部变量哦!
  9. var a; //局部变量a在这行声明
  10. alert(a); //a还是为4,这是因为之前已把4赋给a了
  11. }
  12. test();
  13. alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
  14. </script>
  1. <script>
  2. var a =1;
  3. function test(){
  4. alert(window.a); //a为1,这里的a是全局变量哦!
  5. var a=2; //局部变量a在这行定义
  6. alert(a); //a为2,这里的a是局部变量哦!
  7. }
  8. test();
  9. alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
  10. </script>

javascript 局部变量和全局变量的更多相关文章

  1. JavaScript局部变量和全局变量的理解

    原文链接:http://www.cnblogs.com/eric-qin/p/4166552.html JavaScript局部变量和全局变量的理解   1 2 3 4 5 6 7 8 9 10 &l ...

  2. JavaScript —— 局部变量和全局变量

    JS的全局变量有3种声明方式: 1.Function 外 var v_myVar; 2.Function 内 v_myVar; 3.window.v_myVar window.v_myVar 全局变量 ...

  3. JavaScript中局部变量与全局变量的不同

    JavaScript中局部变量与全局变量 我们知道,JavaScript的变量是松散型的变量,也就是说,其变量只需用var声明,其赋值的类型是不限定的.比如: var person=18; perso ...

  4. javascript 关于局部变量和全局变量

    js中函数运行过程不仅仅是单纯的局部变量覆盖全局变量.和函数里面的声明情况有关. 比方: <script> var a =1; function test(){ alert(a); //a ...

  5. Javascript中的局部变量、全局变量的详解与var、let的使用区别

    前言 Javascript中的变量定义方式有以下三种方式:1.直接定义变量,var与let均不写: a = 10; 2.使用var关键字定义变量 var a = 10; 3.使用let关键字定义变量 ...

  6. 对JavaScript中局部变量、全局变量和闭包的理解

    对js中局部变量.全局变量和闭包的理解 局部变量 对于局部变量,js给出的定义是这样的:在 JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它.(该变量的作用域 ...

  7. javascript当中局部变量和全局变量

    2)局部变量和全局变量 马克-to-win:浏览器里面 window 就是 global,通常可以省.nodejs 里没有 window,但是有个叫 global 的.例 3.2.1<html& ...

  8. js方法入参或局部变量和全局变量重名,用来赋值全局变量会失败

    今天遇到个bug,最后终于知道原因了,js方法入参和全局变量重名,用入参赋值全局变量失败,就是说方法入参不能和全局变量重名. 现在下面的例子也说明,局部变量和全局变量不可以同名不光是入参,只要同名赋值 ...

  9. JavaScript局部变量变量和函数命名提升

    之前接触了一些javascript局部变量命名提升的问题但是一直没有总结今天特地好好总结一下 变量提升 一个变量的作用域是程序源代码中定义的这个变量的区域.全局变量拥有全局作用域,在javascrip ...

随机推荐

  1. Broadcast Reveiver作用

    Broadcast Reveiver作用以及为何要引入(用来接收系统以及自定义消息的) 在系统内通知和判定执行状态 1,系统执行状态,开机了,TF卡插拔,准备关机,电量低了, 2,自定义执行状态,发消 ...

  2. sharepoint 2013 文档库eventhandle权限控制

    记录一下如何在sharepoint server 2013文档库中,使用eventhandle控制文档库document library的条目item权限. ///<summary> // ...

  3. linux下编译运行驱动

    linux下编译运行驱动 嵌入式linux下设备驱动的运行和linux x86 pc下运行设备驱动是类似的,由于手头没有嵌入式linux设备,先在vmware上的linux上学习驱动开发. 按照如下方 ...

  4. 10161 - Ant on a Chessboard

    Problem A.Ant on a Chessboard Background One day, an ant called Alice came to an M*M chessboard. She ...

  5. JavaScript系列文章:详解正则表达式之三

    在上两篇文章中博主介绍了JavaScript中的正则常用方法和正则修饰符,今天准备聊一聊元字符和高级匹配的相关内容. 首先说说元字符,想必大家也都比较熟悉了,JS中的元字符有以下几种: / \ | . ...

  6. 分享下mac安装xamarin跨平台开发环境的坑

    之前在vs2015上安装好了xamarin环境,考虑到调试IOS仍然需要mac机,昨天决定直接在mac上安装xamarin. 安装完所有的效果如上图,此时已经可以创建安卓和IOS环境. 我安装过程中, ...

  7. 【repost】js字符串函数

    JS自带函数concat将两个或多个字符的文本组合起来,返回一个新的字符串.var a = "hello";var b = ",world";var c = a ...

  8. js实现购买数量加减效果

    写在前面:当我们需要在多个页面都有操作数量的需求时的一种解决方案 结构: js代码: <script type="text/javascript"> function ...

  9. Egret --视觉编程,显示对象,事件

    1,在egret中,视觉图形都是由显示对象和显示对象容器组成的: 显示对象:准确的说,就是在舞台上显示出来的,包括能真实看见的图形,文字,图片,视频等:也包括不能看见但真实存在的显示对象容器: 一:显 ...

  10. ACM第五次积分赛

    做出三道题,第二名,总积分上升到第八名,继续加油! SAU-ACM总比赛成绩 姓名     账号  上学期成绩 第一次成绩 第二次成绩 第三次成绩 第四次成绩 第五次成绩 总成绩 张国庆 143401 ...