作用域和作用域链

由于工作原因最近这段时间需要疯狂研究javaScript,这里记录了平时可能遇到的问题以及出现问题的原因和解决办法。

什么叫作用域?

作用域就是变量和函数的可访问范围,控制着变量和函数的可见性与生命周期,在JavaScript中变量的作用域有全局作用域和局部作用域;在java中作用域就是一个{}花括符是块级作用域,而javaScript没有块级作用域,只有函数级作用域。

局部作用域定义全局作用域相同的名称的变量。

    <script>
        var flag="外面"; //全局作用域
        function t(){
            console.log(flag);  //打印: undefined
            var flag="里面"     //局部作用域
            console.log(flag);  //打印: 里面
        }
        t();
    </script>

上面为什么第一个console没有打印”外面”而是”undefined”?因为在函数t()中定义了 var flag=”里面”虽然定义在第一个console下面但是该方法在编译的时候回将t()函数编译为:

    <script>
        var flag="外面";
        function t(){
            var flag;   //这里flag变量在最上面定义了。
            console.log(flag);
            flag="里面"  //在这里其实是赋值的操作。
            console.log(flag);
        }
        t();
    </script>

看到这里就明了了,其实第一个console打印的是刚定义的flag所以是undefined。
解决办法:在函数中局部变量定义的最好放在该函数的顶端也就是函数开始的时候。

全局变量的污染

    <script>
        var flag="外面";//全局变量
        function t(){
             flag="里面";  //在函数中污染全局变量
        }
        t();
       !function (){
           console.log(flag); //打印"里面"
        }();
    </script>

这里打印的为什么是”里面呢”?因为t()函数将flag全局变量污染了,javascript中没有用var声明的变量都是全局变量,而且是顶层对象的。因为函数t()中没有加var 来定义局部变量flag导致全部变量flag就被”里面”赋值了。
解决办法:在方法中局部变量申明一定要记得加上var不然将会变为申请全局变量,导致变量污染。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作用域是指在程序中定义变量的区域,它决定了变量的可见生命周期作用域链是在函数执行时形成的,它是由当前函数作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量函数作用域链的形成是在函数执行时发生的。当一个函数被调用时,会创建一个新的执行上下文,并将该执行上下文的作用域链初始化为当前函数作用域。然后,它会将上一级函数变量对象添加到作用域链中,形成一个链式关系。这样,当在当前函数访问一个变量时,会先在当前函数作用域中查找,如果找不到,就会继续在上一级函数作用域中查找,直到找到或者到达全局作用域。 通过作用域链函数可以访问到上层作用域中的变量函数,但上层作用域不能访问到下层作用域中的变量函数。这种嵌套的作用域作用域链的机制,使得程序可以灵活地组织和管理变量函数,提高了代码的可读和可维护。 范例:<<引用:而作用域链,就是有当前作用域与上层作用域的一系列变量对象组成,它保证了当前执行的作用域对符合访问权限的变量函数的有序访问。 。 引用:作用域链scopeChain的形成:作用域链是在函数执行的时候形成的。他包括当前函数作用域[[scope]]、当前执行的上下文EC,以此来建立的一个链式关系 。 请回答我或者给我介绍或演示一下:什么是作用域作用域链? 作用域是指在程序中定义变量的区域,它决定了变量的可见生命周期作用域链是在函数执行时形成的,它是由当前函数作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量函数

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值