js初学者,如果之前接触的有其他编程语言的经验,往往容易被js代码的执行结果,感觉到莫名其妙,其实很多时候,不太了解,其中的变量提升的原理。
如下代码所示:
console.log(a);//输出函数体
var a = 15;
function a() {
console.log("a");
}
console.log(a);//15
如果没有接触过js,肯定想不明白是怎么回事,其实在js执行过程中,有个过程问题。先把变量的声明提升到作用域的最上面,然后提升声明类型函数(此处区别与另外一种函数的定义,函数表达式,如 var fn=function(){};),所以呢,上面的语句就改写为:
var a;
function a(){
console.log("a");
}
console.log(a);
a=15;
console.log(a);
上面定义了两个变量a ,这里把function a .....同样当做变量啊的声明,那么下面声明的a,就覆盖了上面声明的a ,显而易见,就得出了上面的结果。