JavaScript—预解析
预解析口诀:先声明再调用
JavaScript代码是由浏览器中的JavaScript解析器来执行的。JavaScript解析器在运行JavaScript代码的时候分为两步:预解析和代码执行。
预解析的变量问题
/*console.log(unknow);*/ // 报错:使用了未定义的变量
console.log(num); // undefined
var num = 0;
预解析的函数问题
fn();
var fn = function () {
console.log(1);
}
预解析:js引擎会把js里面所有的var和function提升到当前作用域的最前面。
代码执行:按照代码的书写顺序执行(从上往下)。
预解析分为变量预解析(变量提升)和函数预解析(函数提升)
变量提升就是把所有的变量声明提升到当前的作用域最前面不提升赋值操作。
函数提升就是把所有的函数声明提开到当前作用域的最前面不调用函数。(函数表达式的调用必须写在函数表达式的下面)
变量预解析执行顺序
/*
console.log(num); // undefined
var num = 0;
*/
//(执行顺序)等价于
var num;
console.log(num);
num = 0;
函数预解析执行顺序
/*
fn();
var fn = function () {
console.log(1);
}
*/
//(执行顺序)等价于
var fn;
fn = function () {
console.log(1);
}