美文网首页
JS作用域

JS作用域

作者: 饥人谷_阿银 | 来源:发表于2019-03-02 20:26 被阅读0次

JS作用域是靠函数来形成。一个函数内定义的变量函数不可访问。
1.每当执行一个函数,即进入一个新的作用域下。
2.当使用一个变量或者给一个变量赋值,变量从自己的作用域下去找。如果找不到,再往上一层作用域找。
3.上一层指函数在哪里声明即在哪一层。
全局作用域和局部作用域中变量的访问权限,其实是由作用域链决定的。
每次进入一个新的执行环境,都会创建一个用于搜索变量和函数的作用域链。作用域链是函数被创建的作用域中对象的集合。作用域链可以保证对执行环境有权访问的所有变量和函数的有序访问。
作用域链的最前端始终是当前执行的代码所在环境的变量对象(如果该环境是函数,则将其活动对象作为变量对象),下一个变量对象来自包含环境(包含当前还行环境的环境),下一个变量对象来自包含环境的包含环境,依次往上,直到全局执行环境的变量对象。全局执行环境的变量对象始终是作用域链中的最后一个对象。
标识符解析是沿着作用域一级一级的向上搜索标识符的过程。搜索过程始终是从作用域的前端逐地向后回溯,直到找到标识符(找不到,就会导致错误发生)。
从下面一个例子来看

var a = 1
function fn1(){
  function fn2(){
    console.log(a);
  }
  var a = 4;
  fn2();
}
fn1() //输出多少

根据上方作用域链的概念可以知道,fn2中并没有定义a,那么就会向上一级作用域寻找,这里的上一级作用域具体指的是函数声明的作用域,在上一级作用域中,变量a=4,因此最后输出为4
再看另外一个例子

var a = 1
function fn1(){
  function fn2(){
    console.log(a);
  }
  fn2();
  var a = 4
}
fn1() //输出多少

和上一个例子稍有不同的是,在fn1内部先执行了fn2,再声明a=4,而这一次并没有和上一个例子一样输出4,而是会输出undefined。这是因为在函数内部的作用域下,同样会适用变量提升的概念。fn1的内部相当于

function fn2(){
  console.log(a);
}
var a;
fn2();
a = 4;

这样不难看出,结果会输出undefined.

相关文章

  • 变量作用域

    变量作用域:静态作用域、动态作用域JS变量作用域:JS使用静态作用域JS没有块级作用域(全局作用域、函数作用域等)...

  • JS作用域的练习

    Js作用域练习demo1 Js作用域练习demo2 JS作用域练习demo3 JS作用域练习demo4 JS作用域...

  • 你不知道的JS-上卷

    作用域整体理解:JS作用域分为函数作用域,全局作用域,with和try catch形成的块级作用域。 JS引擎在编...

  • js 闭包

    一、js 作用域 讲闭包首先就要理解 js 的作用域。再 ES5 中,js 有两种作用域,全局作用域和函数作用域(...

  • 2019-08-13JS里面的作用域Scope

    作用域指一个变量的作用范围。 JS的作用域 在JS中,有两种作用域 全局作用域直接编写在script标签中 JS代...

  • 干货!月薪80k前端大佬面试笔记:JS闭包解析!

    三点注意事项 JS没有块级作用域,只有全局作用域和局部作用域(函数作用域)。 JS中的作用域链,内部的作用域可以访...

  • JavaScript作用域的理解

    作用域:就是起作用的区域。JS的作用域规定了变量和函数可访问的范围。JS作用域分为:全局作用域和局部作用域 全局作...

  • JS 作用域链、导入导出

    1. JS 的作用域链 作用域在 JS 中表示变量的可访问性和可见性。JS 作用域有 3 种:1. 全局作用域;2...

  • JS的作用域

    JS的作用域: 全局作用域、函数作用域、eval 作用域、块级作用域 全局作用域: 函数作用域: 结果截屏: 说...

  • ES5中JS的作用域和变量提升(hoisting)

    ES5 中JS 的作用域: 在ES5 中,JS 只有两种形式的作用域:全局作用域和函数作用域。 全局作用域全局对象...

网友评论

      本文标题:JS作用域

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