美文网首页
作用域链

作用域链

作者: hhuwc | 来源:发表于2017-12-12 19:18 被阅读0次

参考文档:《深入理解javascript原型和闭包系列

我们来看如下的代码:

var num = 20;
function f1() {
  console.log(num); // undefined
  var num = 10;
  console.log(num); // 10
}
f1();

==很奇怪为什么,第一个打印num的结果不是 20?为什么第二个又是10?==

这里先引出一个基本知识,==javascript中没有块级作用域的概念,只有全局作用域,和函数作用域==。

  1. 所谓作用域,通俗的可以理解为一个地盘,里面的函数、变量、常量都属于这个作用域;

全局作用域是指函数、变量、常量等对象的作用范围在整个应用程序中都是可用的。在全局作用域内定义的对象被称之为全局对象。例如,在全局作用域内定义的函数被称为全局函数,在全局作用域内定义的变量称之为全局变量。全局对象的生命期开始于应用程序的运行,结束于应用程序的退出。

函数作用域则可以理解为函数大括号所囊括的地盘,里面的函数、变量、常量只在这个范围内可用。

我们回到开头的例子,调用f1()时,进行了哪些准备工作;

  • 变量、函数表达式——变量声明,默认赋值为undefined;
  • this——赋值;
  • 函数声明——赋值;

所以我们在执行 f(); 其实做了相当于如下的过程:

function f1() {
  var num;
  console.log(num); // undefined
  num = 10;
  console.log(num); // 10
}

先对 num 进行了声明,但是没有赋值;

那么为什么 num 使用的不是 全局作用域里的 num = 20 呢?

因为 ==子作用域中的变量优先级比父亲作用域的中优先级高,当子作用域中没有这个变量是才会去父作用域中寻找==所以,第一行输出结果会是undefined,第二行结果是10;

var a = 1
function fn1(){
  function fn3(){
    var a = 4
    fn2()
  }
  var a = 2
  return fn3
}
function fn2(){
  console.log(a)
}
var fn = fn1()
fn() //   输出  1

最后我们看看上面的例子,结果会是1 ,因为 fn2() 是属于全局作用域的,自身作用域中没有a 变量所以会去,全局作用域寻找。

相关文章

  • 作用域链和闭包

    在谈作用域链之前先说一下与作用域链关系紧密的执行环境和作用域。 作用域:作用域指的是变量的适用范围。 作用域链:作...

  • 作用域链

    作用域链 把多个作用域串起来便形成了作用域链;每个函数在初始化完成之后就拥有了各自的作用域链,但此时的作用域链中并...

  • web性能实践

    一. 作用域 前面我们了解作用域概念的以及作用域链是如何运作的。 随着作用域链中的作用域数量的增加,访问当前作用域...

  • JS_0: 执行环境和作用域链

    JavaScript,目前对于执行环境和作用域链的理解 什么是作用域链? 要讲作用域链就得先讲执行环境。 每个函数...

  • js 总结七07-19

    作用域 全局 局部 作用域链 闭包

  • 作用域和闭包

    作用域链 (据我所知)所有的编程语言都存在作用域链。整个代码存在全局作用域、函数作用以及块级作用域。 上述代码将会...

  • 2023-01-12

    变量提升调用栈块级作用域作用域链和闭包 闭包 => 作用域链(词法作用域) => 调用栈(栈溢出) => 上下文...

  • JavaScript 作用域链与闭包

    作用域链与闭包 了解作用域链之前需要先了解下作用域是什么。 作用域 几乎所有的语言都有作用域的概念。这是因为它们都...

  • 作用域/作用域链 闭包及其使用

    一、作用域、作用域链 作用域(scope) 浅显的理解: 作用域就是变量的可用范围(scope) 为什么要有作用域...

  • 作用域链

    作用域链(scope chain) 理解: 作用域链决定了哪些数据能被函数访问。当一个函数创建后,它的作用域链会被...

网友评论

      本文标题:作用域链

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