关于 javascript 的变量提升(Hoisting)

现象

先上一个 javascript 变量提升的案例

console.log(a);
var a = 10;

正常来说,按照代码从上往下执行的逻辑思维,这里 console.log(a) 应该报错
Uncaught ReferenceError: a is not defined,但事实上输出值为 undefined,也就是说 javascript 引擎认为这个 a 变量是已声明,但未赋值而已。

原理

javascript 引擎声明、执行是两个步骤,声明都是在执行前面处理的,所以在代码的任意位置声明总是相当于在代码开头声明,函数赋值是在执行阶段处理的,也就是说 var a = 10; 是分为两个步骤完成

var a;
a = 10;

因此,变量声明是一种提升的处理,所以叫变量提升。变量提升不管在什么作用域中都一样存在(ES6 中的 let 不存在),且函数调用也一样成立

test(); // 1111
function test(){
    console.log(1111);
}

然而,编程体验性也很重要,因此最好是先声明后调用,养成良好的编程习惯。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值