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

发布于 2022-09-02 12:59:12 字数 286 浏览 15 评论 0

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

反话 2022-09-09 12:59:12

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

// 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限定,成了隐式的全局变量了。

离不开的别离 2022-09-09 12:59:12

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文