作用域

作者: jusimple | 来源:发表于2019-06-06 21:09 被阅读0次

    何为作用域

    任何编程语言都有作用域的概念,简单来说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。

    js的作用域是靠函数来形成的,也就是说一个函数的变量在函数外不可以访问。

    1全局作用域

    任何地方都能访问到的对象拥有全局作用域。

    1.1函数外面定义的变量拥有全局作用域

    var n = 2;

    function fn() {

      var a = 1;

      return a;

    }

    console.log(fn());  //1

    console.log(n);  //2

    console.log(a);  //报错error

    1.2未定义直接赋值的变量自动声明为拥有全局作用域

    var n = 2;

    function fn() {

      a = 1;

      return a;

    }

    console.log(fn());  //1

    console.log(n);  //2

    console.log(a);  //1

    2局部作用域

    局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部,所以在一些地方会把这种作用域成为函数作用域。

    图一中,a是函数内部声明并赋值,拥有局部作用域,只能带函数fn内部使用,在fn外部使用就会报错,这就是局部作用域的特性,外部无法访问。

    作用域链

    通俗地讲,当声明一个函数时,局部作用域一级一级向上包起来,就是作用域链。

    当执行函数时,总是先从函数内部找寻局部变量

    如果内部找不到(函数的局部作用域没有),则会向创建函数的作用域(声明函数的作用域)寻找,依次向上

    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

    原因:先执行fn1,返回值是fn3的函数表达式,此时fn1的局部作用各变量已经赋值完毕;将fn3赋值给fn,即fn=function (){var a=4;fn2()};执行fn,调用执行fn2,fn2下没有定义a往上层作用域找,找到var a = 1,所以 console.log(a)等于1。

    相关文章

      网友评论

          本文标题:作用域

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