提前,赋值情况不变。比如 var a = 100; js解析器会把var a;提到前面,原来的则变为a=100;位置不变;function也一样,
然后在一行一行的执行代码。
第一种情况:(先执行,在定义)
alert(a); //function a(){ alert('666') }
var a = '100';
function a(){ alert('666') }
alert(a); //100
第二种情况:(先执行,在定义,嵌套函数)
alert(a); //undefined
var a = 0;
alert(a); //0
function fn(){
alert(a); //undefined;遇到函数,重新进行预解析
var a = 2; alert(a); //2
}
fn()
alert(a); //0
第三种情况:(变量在不同的作用域)
alert(a); //undefined
var a = 0;
alert(a); //0
function fn(){
alert(a); //0;因为没var, 所以这里的a会被看作是全局的,往上查找,找到a=0,所以是0,如果全局也没有就会报错
a = 2;
alert(a); //2
}
fn();
alert(a); //2 全局变量a已被函数内的a=2给修改了
第四种情况:(传参与作用域)
function fn(a){
alert(a); //undefined,JS会把传参当作var一样对待,相当于在fn内部定义了一个变量--> var a;
a = 2;
alert(a); //2,这里修改的不是全局的a,改的是fn的局部变量
}
fn();
alert(a); //Error a is not defined
第五种情况:(参数是函数)
function a(b){
//传参后进行预解析 -> b = c函数,然后往下找 b = b函数,最后b = b函数
alert(b);
function b(){
alert(b);
}
b();
}
a(c); //b函数, b函数
function c(){ return 123; }
定义:js预解析就是在代码执行之前,先在相应环境中寻找var和function,一个是声明变量,一个是声明函数,会把声明提前,赋值情况不变。比如 var a = 100; js解析器会把var a;提到前面,原来的则变为a=100;位置不变;function也一样,然后在一行一行的执行代码。第一种情况:(先执行,在定义)alert(a); //function a(){ alert('666