Javascript全局变量和局部变量

Javascript全局变量和局部变量Javascript全局变量和局部变量先看一段代码:<script>vara=1;functiontest(){alert(a); vara=2;alert(a);}test();alert(a);</script>运行结果:undefined21而一般我们会认为:结果应该是121再看一段代码:<script>vara=1; functiontest(){

大家好,又见面了,我是你们的朋友全栈君。

Javascript全局变量和局部变量

先看一段代码:

<script>
    var a =1;
function test(){ 
   
    alert(a);	
    var a = 2;
    alert(a);
}
test();
alert(a);
</script>

运行结果:

undefined 2 1

而一般我们会认为:结果应该是1 2 1

再看一段代码:

<script>
    var a =1;
	function test(){ 
   
        var b = window.a;
        alert(b);	
        var a = 2;
        alert(a);
	}
    test();
    alert(a);
</script>

运行结果:

1 2 1

再看一段:

<script>
    var a =1;
	function test(){ 
   
        alert(a);	
    }
test();
alert(a);
</script>

运行结果:

1 1

那么为什么这里的alert(a);就不是undefined了呢?

再看一段代码:

<script>
    var a =1;
    b = 5;
    var b;
	alert(b);	

	function test(){ 
   
        alert(a);	
        var a = 4;	
	}
    test();
    alert(a);
</script>

运行结果:

5 undefined 

1. 原因分析

首先:var a =1; 是全局变量,属于window对象。

  1. Javascript在执行前会对整个脚本文件的**定义部分(注意,并不包括赋值部分)**做完整分析,所以在函数test()执行前,函数体中的变量a就被指向内部的局部变量.而不是指向外部的全局变量. 但这时a只有声明,还没赋值,所以输出undefined。
  2. 简单说:函数外部定义的变量为全局变量,如果函数内只是引用改变量,如alert(a),并没有其余的重声明语句,那么这个a仍是全局变量,输出的也是全局变量的值。但是,一旦在函数内重新声明了与全局变量同名的变量,不管是否赋值了,那么这个函数内的变量就是局部变量了。
  3. 且Javascript在执行前会只是对整个脚本文件的**定义部分(注意,并不包括赋值部分)**做完整分析,并不会解析赋值,所以在语句执行时,仍是自上而下,那么在函数体内,a已经被解析为局部变量,且没有给a赋值,a自然是undefined。

附:

<script>
    var a =1;
    function test(){ 
   
        alert(a); //a为undefined! 这个a并不是全局变量,这是因为在function scope里已经声明了(函数体倒数第4行)一个重名的局部变量,
                     //所以全局变量a被覆盖了,这说明了Javascript在执行前会对整个脚本文件的定义部分做完整分析,所以在函数test()执行前,
                     //函数体中的变量a就被指向内部的局部变量.而不是指向外部的全局变量. 但这时a只有声明,还没赋值,所以输出undefined。
        a=4       
        alert(a);  //a为4,没悬念了吧? 这里的a还是局部变量哦!
        var a;     //局部变量a在这行声明
        alert(a);  //a还是为4,这是因为之前已把4赋给a了
    }
    test();
    alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
</script>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130523.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Ubuntu 搭建opengrok 流程

    Ubuntu 搭建opengrok 流程opengrok平台搭建流程软件下载链接:https://pan.baidu.com/s/1kCeXNlj2l3FujyMza3rM0w提取码:iniy搭建前的准备电脑系统电脑系统推荐使用ubuntu16,这版系统较为稳定。细节未更新python环境推荐使用python2.7及以上版本,这一版本相对稳定,python安装细节未更新java环境推荐使用JDK1.8及以上版本,具体安装细节未更新通过java-version和javac-version可以查看版本。Ope

    2022年5月27日
    75
  • 小米手机解BL锁教程

    小米手机解BL锁教程1.找到设置,找到我的设备2.点击全部参数,点miui版本,点3下。3.返回,找到更多设置4.找到开发者选项5.找到设备定状态6.绑定账号和设备,关机,按开键加音量减,进去fast模式,链接电脑。7. 电脑打开下载解锁工具:点击链接下载将解锁工具解压缩,点击unlock.exe。7.解锁工具里登入可解锁的小米账号,同时将手机进入fastboot模式(关机状态下长按音量下键和电源键),用数据线连接电脑,提示已连接手机即可,若没有驱动点击图标安装即可。8.设备已解锁-解锁成功

    2022年6月12日
    53
  • c++学生管理系统源代码_学校运营管理系统

    c++学生管理系统源代码_学校运营管理系统C#学员管理系统C#学员管理系统是在控制台输出的项目,和OOP学员管理系统相似。①创建一个学员的实体类Student,实现其构造方法和封装:usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;///<summary>///实体类///</sum…

    2022年9月20日
    0
  • pycharm下载pandas包失败_pycharm下载包很慢

    pycharm下载pandas包失败_pycharm下载包很慢Pycharm使用安装各种包下载速度慢问题快捷键安装各种包python3-mpipinstallnumpy控制台用这段代码,所有包应该都可以下载下载速度慢问题pip下载速度一般几十k,下着下着就超时了,我用这个大佬的方法解决了MAC下的这个问题MAC解决pip3下载速度慢的问题快捷键最后记录一些经常用的MACPycharm快捷键,方便使用option+commend+L代码格式化control+r运行commend+backspace删除光标所在行

    2022年8月29日
    3
  • FCoin近1.3万BTC无法兑付,有人报案有人自救

    作者:邱祥宇继7.2亿代币销毁,三天三公告之后,FCoin又有新进展。2月17日晚上,张健在FCoin官网发布一篇名为《FCoin真相》的公告,对FCoin的现状、原因以及后续计划作出说…

    2022年4月9日
    53
  • impala读不到hive导入的数据(或者表找不到)

    impala读不到hive导入的数据(或者表找不到)

    2021年5月13日
    155

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号