关于js的变量作用链

/*作用域链由来:默认情况下,全局作用域成为0级链,函数可以开辟一个局部作用域,而函数内部又可以声明函数形成
新的作用域,以此类推,就形成了作用域链

变量在作用域链的访问规则:就近原则
    * 当在一个作用域中访问变量时,首先在自身当前作用域寻找变量的声明,如果有声明访问的就是自身作用域的变量
   如果没有声明,就在父级作用域中寻找声明,如果没有继续往父级找,一直找到顶级链,如果还没有程序就报错

 */
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>


<script>

    /*作用域链由来:默认情况下,全局作用域成为0级链,函数可以开辟一个局部作用域,而函数内部又可以声明函数形成
    新的作用域,以此类推,就形成了作用域链

    变量在作用域链的访问规则:就近原则
        * 当在一个作用域中访问变量时,首先在自身当前作用域寻找变量的声明,如果有声明访问的就是自身作用域的变量
       如果没有声明,就在父级作用域中寻找声明,如果没有继续往父级找,一直找到顶级链,如果还没有程序就报错

     */
    var num = 10;//0级链

    function fn1 (  ) {//0级链,只有函数内部声明的变量才开辟局部作用域,函数本身还是全局变量
        var num = 20;//1级链
        console.log ( num );

        function fn2 (  ) {//1级链
            var num = 50;//二级链
            console.log ( num );//50
        }

        fn2();
    }

    fn1();
</script>
</body>
</html>

猜你喜欢

转载自blog.csdn.net/zjhzjh893/article/details/81708197
今日推荐