迷惑性的js烧脑面试大赏,你真的明白了么

文章详细阐述了JavaScript中的变量赋值顺序、作用域链以及变量提升的概念。通过示例解释了let命令的块级作用域特性,以及如何在函数内部修改全局变量b的值。同时,探讨了if语句中var声明的变量提升,导致在函数内覆盖了全局变量的情况。此外,还讨论了不同数据类型与数字相加时的特殊行为,如NaN、null、对象等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

let a = b = 10
;(function(){ 
  let a = b = 20 
})()
console.log(a) // 10
console.log(b) // 20

analysis:
连等操作从右向左执行,相当于 b = 10、let a = b,b没有声明就赋值了,所以会隐式创建为一个全局变量,函数内也一样,并没有声明b,直接对b赋值,因为作用域链,会一层一层向上查找,找到了全局的b,所以全局的b就被修改为了20,而函数内的a因为重新声明了,所以只是局部变量,不影响全局的a,所以a还是10

var name = 'World'
;(function () {
  if (typeof name === 'undefined') {
    var name = "Jack"
    console.info('Goodbye ' + name)
  } else {
    console.info('Hello ' + name)
  }
})() // Goodbye Jack

analysis:
变量提升,var声明变量时会把变量自动提升到当前作用域顶部,所以函数内的name虽然是在if分支内声明的,但是也会提升到外层,因为和全局的变量name重名,所以访问不到外层的name,最后因为已声明未赋值的变量的值都为undefined,导致if的第一个分支满足条件。

console.log(1 + NaN) // NaN
console.log("1" + 3) // '13'
console.log(1 + undefined) // NaN
console.log(1 + null) // NaN
console.log(1 + {}) // 1[object Object]
console.log(1 + []) // 1
console.log([] + {}) // [object Object]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值