作用域和作用域链

作用域

作用域定义了变量的可见性或可访问性。就是一个变量能不能被访问或引用,是由它的作用域决定的。
在js中存在三种作用域:

- 全局作用域
- 函数作用域
- 块级作用域(ES6以后存在的)

区别:
  • 全局作用域中定义的变量会挂载到window对象身上,定义在最外层,在任何地方都可以访问到全局作用域中的变量
  • 在函数内定义的变量则属于函数作用域,又称局部作用域。局部作用域内的变量只能在自身作用域内被访问。如果在函数外部访问函数内的变量是无法访问的,但是函数内部可以访问到函数外部的变量。
var a = 1;
function test(){
   var b = 2;
   console.log(a); //可以访问到a 结果为1
}
console.log(b); //会报错 b is not defined
  • ES6 中引入了 let 与 const,与 var 不同的是,在大括号(包括纯粹的大括号、if、while、for)间用 var 定义的变量处在全局作用域。如果我们用 let 与 const 在大括号中定义,变量将处于块作用域。
  • 块级作用域内的变量只能在自身作用域内被访问
{
let a = 1;
}
console.log(a); //无法访问到 a is not defined

作用域链

当一个变量在当前作用域无法找到时,便会尝试寻找其外层的作用域,如果还找不到,再继续往外寻找(只会往外寻找,不会寻找兄弟作用域,更不会往内寻找)。这种如同链条一样的寻找规则便被称为作用域链。
注意:函数的作用域是定义时的作用域,而不是调用时的作用域

作用域的优点

  • 防止命名冲突,因为代码写的多了,可能会存在重名的情况自己也记不住,但是由于存在作用域,所以在不同的作用域中写同名变量是可以的,比如A函数我定义了变量item,B函数中也定义了变量item,这时候是在两个作用域中,所以不会冲突
  • 安全性强。变量不会被外部访问,保证了变量值不会被随意修改。
  • 语法更加高级
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作用域是指在程序中定义变量的区域,它决定了变量的可见性和生命周期。作用域链是在函数执行时形成的,它是由当前函数的作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量和函数。 作用域链的形成是在函数执行时发生的。当一个函数被调用时,会创建一个新的执行上下文,并将该执行上下文的作用域链初始化为当前函数的作用域。然后,它会将上一级函数的变量对象添加到作用域链中,形成一个链式关系。这样,当在当前函数中访问一个变量时,会先在当前函数的作用域中查找,如果找不到,就会继续在上一级函数的作用域中查找,直到找到或者到达全局作用域。 通过作用域链,函数可以访问到上层作用域中的变量和函数,但上层作用域不能访问到下层作用域中的变量和函数。这种嵌套的作用域作用域链的机制,使得程序可以灵活地组织和管理变量和函数,提高了代码的可读性和可维护性。 范例:<<引用:而作用域链,就是有当前作用域与上层作用域的一系列变量对象组成,它保证了当前执行的作用域对符合访问权限的变量和函数的有序访问。 。 引用:作用域链scopeChain的形成:作用域链是在函数执行的时候形成的。他包括当前函数的作用域[[scope]]、当前执行的上下文EC,以此来建立的一个链式关系 。 请回答我或者给我介绍或演示一下:什么是作用域作用域链? 作用域是指在程序中定义变量的区域,它决定了变量的可见性和生命周期。作用域链是在函数执行时形成的,它是由当前函数的作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量和函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值