Javascript之全局变量和局部变量

本文解析了JavaScript中全局变量与局部变量的概念,探讨了局部变量如何覆盖全局变量的现象,并深入讲解了变量提升这一特性,通过实例代码展示了变量提升如何影响程序的执行结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于全局变量和局部变量的一句简单的定义:在函数外声明的变量都为全局变量,在函数内声明的为局部变量。

一、局部变量和全局变量重名会覆盖全局变量

var a = 1;  
 function test1() {  
   var a = 2;  
   alert(a);  
 }  
 test1();// 2  
复制代码

这里的函数中的定义的a是局部变量,它的作用域为函数{}之间,函数外定义的a为全局变量,它的作用域为整个程序(描述有点不准确)。在函数中的局部变量和全局变量重名,局部变量会覆盖全局变量。

二、提到全局变量与局部变量不得不说明的一个知识点就是**变量提升**。‘与C/C++逐行执行代码不同,JS引擎的工作方式是,先获取所有被声明的变量再逐一执行,所有变量的声明语句都会被提升到当前代码块的头部’。注:代码块指的是function的一个{},通常的if、while、for的{}中变量不会提升。

了解了变量提升了之后我们用以下代码来演示:

var a = 1;  
function test1() {  
    alert(a);  
    var a = 2;  
    alert(a);  
}  
test1();   
alert(a);//undefined  2  1
复制代码

为什么结果不是1 2 1呢?原因就在于代码提升。由于代码提升的效果所以实际执行的代码是这样的:

var a = 1;  
function test1() {  
   var a;//局部变量与全局变量重名时会覆盖全局变量,此时的a只有声明却未定义  
    alert(a);//所以执行alert值为undefined  
    a = 2;  
    alert(a);  欢迎加入全栈开发交流群一起学习交流:864305860
}  
test1();  
alert(a);//undefined  2
复制代码

结语

感谢您的观看,如有不足之处,欢迎批评指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值