这个JS题目是函数声明提升导致的结果吗?

var a = b = null;
(function a(c){
    console.log(a) //这里是function
 return a =c;
})(1)
console.log(a) //这里是null

但是如果换一种写法:

var a = b = null;
(function b(c){
    console.log(a) //这里是null
 return a =c;
})(1)
console.log(a) //这里是1
阅读 2.3k
2 个回答

不是,是因为函数内的局部作用域。
第一个例子

// a 和b 都是全局变量;
var a = b = null;
(function a(c) {
    console.log(a); // 因为a 函数被括号包裹,因此此处a 是局部变量(就是这个函数自己),在括号内覆盖了全局变量a
    return a = c; //只是给函数a 赋值为c,不影响全局变量a
})(1)
console.log(a) // 括号外是全局变量

第二个例子:

// 此行同第一个例子
var a = b = null;
(function b(c){
    console.log(a) // 括号内b 是局部变量,但a 没有重新定义过,所以直接指向全局的a
    return a = c; // 所以这里给外面的全局变量a(值为null)赋值
 return a =c;
})(1)
console.log(a) // 已赋值为1

另外补充一个点:

var a = b = null;

不推荐这样的定义法,因为这一句实际等价于:

var a = null;
b = null;

b实际上没用var限定,成了隐式的全局变量了。

这个就是作用域的问题吧,第一种情况a可以获取到,就是函数本身,第二种情况找不到a,就会去外层作用域寻找。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题