JavaScript作用域与作用域链

作用域规定了变量能被访问的“范围”,离开了这个“范围”,变量就不能被访问了

作用域分为 全局作用域 和 局部作用域,局部作用域又分为 函数作用域 和 块作用域

 

一、局部作用域

局部作用域分为 函数作用域 和 块作用域

1、函数作用域:在函数内部声明的变量只能在函数内部被访问,外部无法直接访问

<script>
  function getSum(){
    // 函数内部是函数作用域属于局部变量
    const num = 10
}
  console.1og(num)  //此处报错函数外部不能使用局部作用域变量
</script>

总结:
1.函数内部声明的变量,在函数外部无法被访问
2.函数的参数也是函数内部的局部变量
3.不同函数内部声明的变量无法互相访问
4.函数执行完毕后,函数内部的变量实际被清空了

2、块作用域

在JavaScript中使用 { } 包裹的代码称为代码块,代码块内部声明的变量外部将【有可能】无法被访问

for (1et t = 1; t <= 6; t++) {
  //t只能在该代码块中被访问
  console.1og(t) //正常
}
//超出了t的作用域
console.1og(t) //报错

总结:

1.let 声明的变量会产生块作用域,var不会产生块作用域
2.const 声明的常量也会产生块作用域
3.不同代码块之间的变量无法互相访问
4.推荐使用 let 或 const

二、全局作用域

<script>标签和.js文件的【最外层】就是所谓的全局作用域,在此声明的变量在函数内部也可以被访问。
全局作用域中声明的变量,任何其它作用域都可以被访问

<script>
  //全局作用域
  //全局作用域下声明了num变量
  const num 10
  function fn() {
    //函数内部可以使用全局作用域的变量
    console.log(num)
}
  //此处全局作用域
</script>


注意:
1.为window对象动态添加的属性默认也是全局的,不推荐!
2.函数中未使用任何关键字声明的变量为全局变量,不推荐!!!
3.尽可能少的声明全局变量,防止全局变量被污染

 

三、作用域链

作用域链本质上是底层的变量查找机制

  • 当函数被执行时,会优先查找当前函数作用域中查找变量
  • 如果当前作用域查找不到,则会依次逐级查找父级作用域直到全局作用域
<script>
// 全局作用域
let a = 1;
let b = 2;

// 局部作用域
function f() {
    let a = 1;

    // 局部作用域
    function g() {
        a = 2;
        console.log(a);
    }

    g(); // 调用g
}

f(); // 调用f
</script>

总结:
1.嵌套关系的作用域串联起来形成了作用域链
2.相同作用域链中按着从小到大的规则查找变量
3.子作用域能够访问父作用域,父级作用域无法访问子级作用域

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值