作用域链

2019-03-15  本文已影响0人  949nb

作用域链

初级理解

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

高级理解

一系列活动的执行上下文(EC)形成了栈。栈底是全局上下文,栈顶是活动的当前上下文,压栈、出栈类似数组的pop以及push

压栈:全局EC-->局部EC1-->局部EC2-->当前EC
出栈:全局EC<--局部EC1<--局部EC2<--当前EC

当JS代码被载入浏览器中时,默认进入的是一个全局的执行上下文。当在全局上下文中调用执行一个函数时,程序流就进入被调用的函数内,此时引擎就会为函数创建一个新的执行上下文,并将其压入到执行上下文堆栈的顶部。浏览器总是执行在当前堆栈顶部的执行上下文,一旦执行完毕,该上下文就会被从当前堆栈弹出,然后,进入其下的上下文执行代码。这样,堆栈中的上下文就会被一直执行并且弹出堆栈,直到回到全局上下文。

var a = 1;

function fn(){
  console.log("1 "+a);
  var a = 5;
  console.log("2 "+a);
  a++;
  var a;
  fn3();
  fn2();
  console.log("3 "+a);

  function fn2(){
    console.log("4 "+a);
    a = 20;
    console.log("8 "+a);
  }
  console.log("9 "+a);
}

function fn3(){
  console.log("5 "+a) 
  a = 200;
  console.log("7 "+a) 
}

fn();
console.log("6 "+a);
输出顺序和结果
上一篇 下一篇

猜你喜欢

热点阅读