一,变量提升
1,在ES6之前,JavaScript没有块级作用域(一对花括号{}即为一个块级作用域),只有全局作用域和函数作用域。
2,变量提升即将变量声明提升到它所在作用域的最开始的部分。
3,JavaScript 只有声明的变量会提升,初始化的不会。
console.log(gobal); //undefined
var gobal = 'gobal';
console.log(gobal); //gobal
function f () {
console.log(part); //undefined
var part = 'part';
console.log(part); //part}
}
之所以会是以上的打印结果,是由于js的变量提升,实际上上面的代码是按照以下来执行的:
var gobal; //变量提升,全局作用域范围内,此时只是声明,并没有赋值
console.log(gobal); //undefined
gobal = 'gobal'; //此时才赋值
console.log(gobal); //gobal
function f () {
var part; //变量提升,函数作用域范围内
console.log(part); //undefined
part = 'part';
console.log(part); //part
}
二,函数提升
1,js中创建函数有两种方式:函数声明式和函数字面量式。只有函数声明才存在函数提升!如:
console.log(f1); //function f1 () {}
console.log(f2); //undefined
function f1 () {};
var f2 = function() {};
2,之所以会有以上的打印结果,是由于js中的函数提升导致代码实际上是按照以下来执行的:
function f1 () {}; //函数提升,整个代码块提升到文件的最开始
console.log(f1);
console.log(f2);
var f2 = function () {};