JavaScript 变量的作用域与生命周期

本文详细探讨了JavaScript中的变量作用域,包括局部变量和全局变量的使用及销毁,强调了函数内外的差异。此外,还介绍了块级作用域的概念,并提醒开发者由于局部变量生命周期短,因此推荐使用局部变量以节省内存。

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

变量的作用域与生命周期

作用域:变量在哪个范围区间内可以使用

生命周期:变量从创建后, 什么时候被销毁掉

作用域

局部变量
函数内部定义的变量, 只能在函数内部使用, 所以称作局部变量
<script>
	function test(){
        let a = 100
    }
    test()
    alert(a) 
     // 在函数外不能访问 函数内部定义的变量
</script>

全局变量

所有函数外部定义的变量, 即可以在函数内部使用,也可以在函数外部使用, 所以称为全局变量
一般情况下函数执行结束,局部变量会被销毁
<script>
	let a = 100
    test()
    function test(){
        alert(a)           // 100     函数内部也可以访问全局变量
    }
</script>
<script>
	let a = 100
    test()
    function test(){
    	let a = 30
        alert(a)  //  30先在当前作用域找,没有的情况下再尝试到更大的作用域中查找
    }
</script>

块级作用域

在代码中单纯的一对大括号 { } 也会被看成特殊的范围, 叫做块级
作用域
块级作用域中用 let和const声明定义的变量和常量, 会在块
级作用域外无效
函数内部是一个范围, 函数外部又是另一个范围,

{
	let str = '哈哈哈'
}
alert(str)       // 报错. str 变量未定义

生命周期

局部变量可以理解为在函数中定义 在函数中使用 函数结束时 自动销毁
全局变量从定义位置开始, 一直到整个代码结束, 才会销毁
因为局部变量占用内存空间的时间短, 所以尽量使用局部变量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值