js中的变量提升

Posted tony-stark

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中的变量提升相关的知识,希望对你有一定的参考价值。

在js中 变量声明与赋值被认为是两个不同的操作,引擎首先会对前者进行优先编译,这部分工作就是找到所有的声明(例如函数声明function b(注:非函数表达式),变量声明var a),既然是优先执行,那么在一些代码结构中,后声明的function,var 变量就会提前解释;

例如 var a=3;引擎会认为这是两个操作  var a(声明); a=3(赋值),简而言之就是 先有蛋 后有鸡,

  理解了这一点 这就很好解释如下的代码结构及其输出

a=2;
var a; //定义声明提升
console.log(a) //得到2

-------------------分割线-------------------

console.log( a );//得到undefined
var a = 2; //等效于var a;//定义声明置顶               a=2;

-------------------分割线-------------------

foo();  //得到666

function()

console.log(666)

-------------------分割线-------------------

foo();  //报错 信息为 Uncaught TypeError: foo is not a function,因为此时 foo为undefined,而不是一个函数

var foo = function()

console.log(6666)

以上是关于js中的变量提升的主要内容,如果未能解决你的问题,请参考以下文章

js中的变量提升与函数提升

JS中的变量声明提升

js中的变量提升和函数提升

函数和变量中的预解析

js中的变量提升

JS预解析与变量提升