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>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 2021版idea激活码99年【2021.8最新】

    (2021版idea激活码99年)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.cn/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~S…

  • java怎样解决除法精度_java 除法 精度问题

    java怎样解决除法精度_java 除法 精度问题inta=4;intb=3;floatc=(float)a/b;System.out.print(c);//输出:1如果要的到精确的结果,要用下面的方法inta=4;intb=3;floatc=(float)a/(float)b;System.out.print(c);//输出:1.3333334importjava.text.DecimalFormat;public…

  • 缓冲区溢出 攻击 「建议收藏」

    缓冲区溢出 攻击 「建议收藏」#缓冲区溢出漏洞实验##缓冲区溢出缓冲区溢出是指程序试图向缓冲区写入超出预分配固定长度数据的情况。这一漏洞可以被恶意用户利用来改变程序的流控制,甚至执行代码的任意片段。这一漏洞的出现是由于数据缓冲

  • EXCEL countif函数多条件

    在MSEXCEL中,countif如果要满足多个条件怎么办呢?1、答案就是:使用条件集合{}和sum函数。即在countif()第二个参数中使用条件集合{},然后用sum()函数求满足这些条件的

    2021年12月26日
  • 成果被他人窃取_工作窃取模式

    成果被他人窃取_工作窃取模式什么是ForkJoin、ForkJoin分支合并、ForkJoin工作窃取、ForkJoin大数据求和计算什么是ForkJoin?ForkJoin:分支合并ForkJoin特点:工作窃取如何让使用ForkJoinForkJoin求和计算Demo什么是ForkJoin?ForkJoin(分支合并)是jdk1.7之后出来的,并行执行任务,提高效率,用在大数据量场景下。大数据:MapReduce(把大任务拆分成多个小任务,怎么拆分用到了二分算法),每个小任务得出自己的结果,之后再把结果汇总,汇总的过程就是

  • 谋哥:研究App排行榜浮出的神器

    谋哥:研究App排行榜浮出的神器

发表回复

您的电子邮箱地址不会被公开。

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