JS作用域链

作者: 凛冬已至_123 | 来源:发表于2018-03-03 23:38 被阅读0次

    JS作用域链

    如题1

    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() //输出多少
    

    题中fn()输出为2

    说明:fn1()执行到最后是fn2(),fn2()内部没有定义变量,所以从当前函数所在的作用域去找,即f1()中查找(fn2()为fn1()的内部函数),fn1()中a=2,所以输出为2.

    题2

    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() //输出多少
    

    题中fn()输出为1

    说明:执行fn1()后最终的调用函数为fn2(),而fn2()中没有定义a,所以从它所在的作用域寻找变量a,不难发现它的作用域是全局,全局变量a为1,所以结果输出为1.

    题3:

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

    结果为:undefined

    说明:执行结果为fn2(),它内部没有定义a,所以从它的作用域去寻找--即fn3(),因为a=4的赋值语句在fn2()后执行,所以此时a只是定义了还没有赋值,所以a为undefined.

    总结:

    • 函数在执行的过程中,先从自己内部找变量
    • 如果找不到,再从创建当前函数所在的作用域去找, 以此往上
    • 注意找的是变量的当前的状态

    相关文章

      网友评论

        本文标题:JS作用域链

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