美文网首页
js作用域链

js作用域链

作者: 此人长期不在线 | 来源:发表于2018-07-24 00:20 被阅读0次

变量提升

JavaScript引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行地运行。这造成的结果,就是所有的变量的声明语句,都会被提升到代码的头部,这就叫做变量提升(hoisting)。

console.log(a);
var a = 1;   //最后的结果是显示undefined,表示变量a已声明,但还未赋值。

上面代码首先使用console.log方法,在控制台(console)显示变量a的值。这时变量a还没有声明和赋值,所以这是一种错误的做法,但是实际上不会报错,因为存在变量提升。

注意:变量提升只对var命令声明的变量有效,如果一个变量不是用var命令声明的,就不会发生变量提升。

console.log(b);
b = 1;  //语句报错,提示“ReferenceError: b is not defined”,即变量b未声明

这是因为b不是用var命令声明的,JavaScript引擎不会将其提升,而只是视为对顶层对象的b属性的赋值。

一、什么是作用域

JS中作用域有:全局作用域、函数作用域。

var x = 10 //x变量是属于全局作用域
function fn2() {
   var y = 9  //y变量是属于函数作用域2
   function fn1(){
      var z = 30  //z变量是属于函数作用域1
      console.log(x)
   }
}

一般来说,我们在查找x变量时,先在函数作用域1中查找,没有找到,再去函数作用域2中查找,没有找到,再去全局作用域中查找,这是一个由内向外查找的过程,即顺着一条链条从下往上查找变量,这种链条,我们就称之为作用域链。

二、根据题目深入理解作用域链

  1. 第一题
var a = 1
function fn1(){
  function fn2(){
    console.log(a)
  }
  function fn3(){
    var a = 4
    fn2()
  }
  var a = 2
  return fn3
}
var fn = fn1()
fn()  //fn()输出为2

fn1()执行到最后是fn2(),fn2()内部没有定义变量,所以从当前函数所在的父容器的作用域去找,即f1()中查找,fn1()中a=2,所以输出为2。

  1. 第二题
var a = 1
function fn1(){
  function fn3(){
    var a = 4
    fn2()
  }
  var a = 2
  return fn3
}
function fn2(){
  console.log(a)
}
var fn = fn1()
fn()  //fn()输出为1

执行fn1()后最终的调用函数为fn2(),而fn2()中没有定义a,所以从它所在的父容器的作用域寻找变量a,即全局作用域,全局变量a为1,所以结果输出为1.

  1. 第三题
var a = 1
function fn1(){
  function fn3(){
    function fn2(){
      console.log(a)
    }
    var a
    fn2()
    a = 4
  }
  var a = 2
  return fn3
}
var fn = fn1()
fn()  //输出undefined

执行结果为fn2(),它内部没有定义a,所以从它父容器的作用域去寻找—即fn3(),因为a=4的赋值语句在fn2()后执行,所以此时a只是定义了还没有赋值,所以a为undefined。

解密

  1. 函数在执行的过程中,先从自己内部找变量
  2. 如果找不到,再从创建当前函数所在的作用域去找, 以此往上
  3. 注意找的是变量的当前的状态

相关文章

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

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

  • JS 作用域链、导入导出

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

  • 闭包

    一、理解闭包前js基础1、作用域链(作用域、作用域链中有说)。2、js的内存回收机制。一个函数在执行开始的时候,会...

  • 作用域和作用链

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

  • 2018-12-18

    JS高级 作用域&作用域链 作用域: 1.作用域的个数:n(函数声明的个数)+1(全局作用域)2.作用域不会存储变...

  • 浅谈JS作用域链

    浅谈JS作用域链 作用域 作用域(scope)就是变量访问规则的有效范围。作用域外,无法引用作用域内的变量;离开作...

  • JS博客

    JS构造函数及new运算符 JS原型对象和原型链 函数作用域和作用域链 干货分享:让你分分钟学会JS闭包 深入理解...

  • JS进阶系列

    在JS入门难点解析系列中,我们对JS的一些重要概念,比如:作用域,作用域链,原型,原型链,继承,活动对象,this...

  • js 作用域链 和 原型链

    作用域链 js拥有全局作用域(window)、函数作用域、块级作用域(es6)。块级作用域是es6开始才拥有的,因...

  • JavaScript 函数闭包(colsure)

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

网友评论

      本文标题:js作用域链

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