JS 作用域和作用域链

作者: lio_zero | 来源:发表于2021-04-21 00:30 被阅读0次

作用域

JavaScript 中的作用域是我们可以有效访问变量或函数的区域。作用域规定了如何查找变量,也就是确定当前执行代码对变量的访问权限。

JavaScript 有两种类型的作用域:全局作用域、局部作用域。局部作用域又可以分为:函数作用域、块作用域(ES6)和其他更具体的作用域。

全局作用域

let age= 18

function foo() {
  // 不是嵌套函数
  // 函数内部可以访问函数外部变量
  return age
}

foo() // 18

函数作用域

function text() {
  var age = 18
}

// 函数外部访问不到函数内部变量
console.log(age) // undefined

块作用域

{
  let age = 18
}

// let、const 关键字声明的变量,只在其所在的代码块 {} 内有效。
console.log(age) // error

词法作用域和动态作用域

词法作用域是在定义时确定的,它关注函数在何处声明。

动态作用域是在运行时确定的(this 也是),它关注函数从何处调用(常与 this 挂钩)。

JavaScript 采用的是词法作用域,又称静态作用域。下面我们来看看示例:

var value = 1

function foo() {
  console.log(value)
}

function bar() {
  var value = 2
  foo()
}

bar() // 1

分析

如果是词法作用域,调用 foo 函数时,会先在其内部作用域中查找,如果找不到,往上一层查找,找到了 value,结果为 1。

如果是动态作用域,调用 foo 函数时,同样会先在其内部作用域中查找,如果找不到,会到调用 foo 函数的作用域中查找(这里是 bar),结果为 2。

作用域链

一般情况下,变量取值应到创建这个变量的函数的作用域中取值。如果在当前作用域找不到,向上级作用域查找,直到全局作用域,这么一个查找过程形成的链条就叫做作用域链。

  1. 每当编译器遇到变量或对象时,它都会遍历当前执行上下文的整个作用域链(Scope chain),以查找它。
  2. 如果没有在那里找到它,它遍历原型链(prototype chain),如果它也没有找到,它会抛出未定义的错误。
  3. 编译器通过查看函数在代码中的位置来创建函数的作用域。
  4. 编译器创建称为作用域链(Scope chain) 的等级层次结构,全局作用域(Global Scope) 位于此层次结构的顶部。
  5. 当代码中使用变量时,编译器会向后查看作用域链,如果找不到,则抛出未定义的错误。

更多资料

相关文章

  • JS 作用域链、导入导出

    1. JS 的作用域链 作用域在 JS 中表示变量的可访问性和可见性。JS 作用域有 3 种:1. 全局作用域;2...

  • 干货!月薪80k前端大佬面试笔记:JS闭包解析!

    三点注意事项 JS没有块级作用域,只有全局作用域和局部作用域(函数作用域)。 JS中的作用域链,内部的作用域可以访...

  • JavaScript散乱(四、细节)

    js高级 案例问题 作用域和作用域链 全局作用域也就是window和函数作用域,不考虑es6的块级作用域前提下,作...

  • 作用域和作用链

    关键词:作用域作用链 作用域 js中没有块级作用域 全局作用域,函数作用域太简单,就不演示(≧▽≦)/啦啦啦 作用...

  • JavaScript 函数闭包(colsure)

    理解闭包,你首先必须理解JS的变量作用域,JavaScript作用域和作用域链。 ES6之前,变量的作用域分为全局...

  • 2018-12-18

    JS高级 作用域&作用域链 作用域: 1.作用域的个数:n(函数声明的个数)+1(全局作用域)2.作用域不会存储变...

  • 变量作用域

    变量作用域:静态作用域、动态作用域JS变量作用域:JS使用静态作用域JS没有块级作用域(全局作用域、函数作用域等)...

  • 你不知道的JS-上卷

    作用域整体理解:JS作用域分为函数作用域,全局作用域,with和try catch形成的块级作用域。 JS引擎在编...

  • js 作用域链 和 原型链

    作用域链 js拥有全局作用域(window)、函数作用域、块级作用域(es6)。块级作用域是es6开始才拥有的,因...

  • 浅谈JS作用域链

    浅谈JS作用域链 作用域 作用域(scope)就是变量访问规则的有效范围。作用域外,无法引用作用域内的变量;离开作...

网友评论

    本文标题:JS 作用域和作用域链

    本文链接:https://www.haomeiwen.com/subject/btxalltx.html