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

作用域链,你太讲究

作者: 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);

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

相关文章

  • 作用域链,你太讲究

    每个对象均有一个内置属性[[scope]],其中存储了对象被创建的作用域中所有对象的集合,这个集合即为作用域链,其...

  • 作用域和作用链

    关键词:作用域作用链 作用域 js中没有块级作用域 全局作用域,函数作用域太简单,就不演示(≧▽≦)/啦啦啦 作用...

  • 作用域链和闭包

    在谈作用域链之前先说一下与作用域链关系紧密的执行环境和作用域。 作用域:作用域指的是变量的适用范围。 作用域链:作...

  • 作用域链

    作用域链 把多个作用域串起来便形成了作用域链;每个函数在初始化完成之后就拥有了各自的作用域链,但此时的作用域链中并...

  • 面试宝典3

    1、说说你对作用域链的理解 作用域链的作用是保证执行环境里有权访问的变量和函数是有序的,作用域链的变量只能向上访问...

  • web性能实践

    一. 作用域 前面我们了解作用域概念的以及作用域链是如何运作的。 随着作用域链中的作用域数量的增加,访问当前作用域...

  • js 作用域链

    什么是作用域链 其实了解了作用域快,你学习作用域链的时候,你就会接受快很多, 当a 创建函数的时候,分为两部 1,...

  • JavaScript 函数闭包(colsure)

    理解闭包,你首先必须理解JS的变量作用域,JavaScript作用域和作用域链。 ES6之前,变量的作用域分为全局...

  • JS_0: 执行环境和作用域链

    JavaScript,目前对于执行环境和作用域链的理解 什么是作用域链? 要讲作用域链就得先讲执行环境。 每个函数...

  • js 总结七07-19

    作用域 全局 局部 作用域链 闭包

网友评论

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

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