声明提前
当js执行的时候遇见var和function函数的时候,将会出现声明提前。这个过程也被叫做,“预解析”或者“预编译”。
- 变量的声明被提前到作用域顶部,赋值保留在原地。
- 函数声明全部被提前。
- 函数作为值赋给变量时函数不提前,只有变量提前。
一.变量声明提前
1.若为以下情况,则第一个console输出的结果为undefined,第二个console输出结果为小明。
<script>
var stu_1;
console.log(stu_1);//输出为undefined,因为变量声明提前
var stu_1='小明';
console.log(stu_1);//输出为小明
</script>
2.若为以下情况,则第一个console输出结果为undefined,第二个console输出结果为小白,第三个console输出结果为也小白
<script>
console.log(stu_2);//输出为undefined,因为变量声明提前
var stu_2='小白';
console.log(stu_2);//输出为小白
var stu_2;
console.log(stu_2);//输出也为小白,因为前面已经对变量进行了初始化
</script>
二.函数声明提前
1.若为以下情况,则console输出结果为日期函数。
<script>
/*具名函数的函数声明提前(可以)*/
console.log(window);
Date;
function Date() {
console.log("日期函数");
}
</script>
2.若为以下情况,则会报错,因为此时fun1不是一个函数
<script>
/*匿名函数的函数声明提前(不可以)*/
fun1();
var fun1 = function () {
console.log("匿名函数")
}
</script>