美文网首页
H5-2.25js作用域与作用域链

H5-2.25js作用域与作用域链

作者: 冬天不爱洗头 | 来源:发表于2017-02-26 15:40 被阅读0次

任何程序设计语言都有作用域的概念,简单的说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。

  1. 全局作用域(Global Scope)

在代码中任何地方都能访问到的对象拥有全局作用域,一般来说以下几种情形拥有全局作用域:

(1)最外层函数和在最外层函数外面定义的变量拥有全局作用域,例如:

 var authorName="山边小溪";
function doSomething(){
var blogName="梦想天空";
function innerSay(){
    alert(blogName);
}
innerSay();
}
  alert(authorName); //山边小溪
  alert(blogName); //脚本错误
  doSomething(); //梦想天空
  innerSay() //脚本错误

(2)所有末定义直接赋值的变量自动声明为拥有全局作用域,例如:

 function doSomething(){
var authorName="山边小溪";
blogName="梦想天空";
alert(authorName);
 }
doSomething(); //山边小溪
alert(blogName); //梦想天空
alert(authorName); //脚本错误
  1. 局部作用域(Local Scope)
    和全局作用域相反,局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部,所有在一些地方也会看到有人把这种作用域称为函数作用域,例如下列代码中的blogName和函数innerSay都只拥有局部作用域。

       function doSomething(){
      var blogName="梦想天空";
     function innerSay(){
    alert(blogName);
     }
    innerSay();
    }
    alert(blogName); //脚本错误
    innerSay(); //脚本错误
    

作用域链和代码优化
从作用域链的结构可以看出,在运行期上下文的作用域链中,标识符所在的位置越深,读写速度就会越慢。如上图所示,因为全局变量总是存在于运行期上下文作用域链的最末端,因此在标识符解析的时候,查找全局变量是最慢的。所以,在编写代码的时候应尽量少使用全局变量,尽可能使用局部变量。一个好的经验法则是:如果一个跨作用域的对象被引用了一次以上,则先把它存储到局部变量里再使用。例如下面的代码:

   function changeColor(){
    document.getElementById("btnChange").onclick=function(){
      document.getElementById("targetCanvas").style.backgroundColor="red";
  };
}

这个函数引用了两次全局变量document,查找该变量必须遍历整个作用域链,直到最后在全局对象中才能找到。这段代码可以重写如下:

function changeColor(){
 var doc=document;
doc.getElementById("btnChange").onclick=function(){
    doc.getElementById("targetCanvas").style.backgroundColor="red";
};
}

这段代码避免了,重复从全局作用域中寻找,当大量使用时可以节省程序反映事件。

相关文章

  • 作用域链和闭包

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

  • H5-2.25js作用域与作用域链

    任何程序设计语言都有作用域的概念,简单的说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生...

  • JavaScript 作用域链与闭包

    作用域链与闭包 了解作用域链之前需要先了解下作用域是什么。 作用域 几乎所有的语言都有作用域的概念。这是因为它们都...

  • JavaScript核心技术开发解密读书笔记(第五章)

    第五章 作用域与作用域链 1. 作用域 常见的作用域有两种,全局作用域和函数作用域。ES6中新增了块级作用域。全局...

  • 作用域和作用域链

    作用域和作用域链 作用域 作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在Java...

  • web性能实践

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

  • JavaScript系列——作用域链

    作用域与作用域链 首先,什么是作用域?先看看 MDN文档的定义: The current context of e...

  • JavaScript函数的执行-作用域链、执行上下文、闭包

    1、作用域与作用域链 作用域 作用域是指程序源代码中定义变量的区域。 作用域规定了如何查找变量,也就是确定当前执行...

  • js中作用域与作用域链

    js中作用域与作用域链 作用域 *作用域基本概念 作用域一般指变量的作用范围,变量分为全局变量和局部变量,对应的作...

  • 作用域链

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

网友评论

      本文标题:H5-2.25js作用域与作用域链

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