变量提升(hoisting)

  • 变量提升(hoisting)已关闭评论
  • 26 次浏览
  • A+
所属分类:Web前端
摘要

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

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

console.log(a); // undefined var a = 1;

上面的代码首先使用 console.log 方法,在控制台显示变量 a 的值。这时变量 a 还没有声明和赋值,应该会报错,但实际上不会报错。因为存在变量提升,真正运行的是下面的代码。

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

最后的结果是显示 undefined,表示变量 a 已经声明,但还未赋值。