美文网首页
作用域链,你太讲究

作用域链,你太讲究

作者: Candy程 | 来源:发表于2017-03-22 09:00 被阅读0次

    每个对象均有一个内置属性[[scope]],其中存储了对象被创建的作用域中所有对象的集合,这个集合即为作用域链,其表示了该对象所能访问的数据范围。

    全局对象,你太能吃了! 最多只管你一顿饭

    对于作用链来说,全局对象总会被放置在作用域链的最下端。举例来说:

    var origin = 'oupp';
    function add(a,b){
       var sum = a+b>10?origin : a+b;
       return sum;
    }
    var result = add(1,3);
    
    scope-chain.png

        从作用域链的结构可以看出,标识符所在的位置越深,读写速度就会越慢。如上图所示,因为全局变量origin总是存在于运行期上下文作用域链的最末端,因此在标识符解析的时候,查找全局变量是最慢的。
        所以,在编写代码的时候应尽量少使用全局变量,尽可能使用局部变量。

    如果一个跨作用域的对象被引用了一次以上,则先把它存储到局部变量里再使用。

    优化上述代码如下:

    var origin = 'oupp';
    function add(a,b){
      var tmp = origin;
       var sum = a+b>10?tmp : a+b;
       return sum;
    }
    var result = add(1,3);
    

    小二,再来一壶茶,要红茶哈,还得呆会~

    相关文章

      网友评论

          本文标题:作用域链,你太讲究

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