js的预解析

预解析:js解析器加载时,会首先检查语法错误,后进行变量声明提升和函数体声明提升,解释一行语句执行一行语句

1.检查语法错误

2.变量声明提升和函数体整体提升(变量提升时只提升变量名)

函数体中也有变量声明提升和函数体声明提升

console.log(a);     //打印为undefined,var a;声明提升
   var a = 100;
   console.log(a);   //打印为100
fn();
function fn(){
console.log(b);   //打印为undefined
var  b = 20;
console.log(b); //打印为20}

console.log(c);     //打印为undefined
   var c = 100;
   console.log(c);   //打印为100
function fn(){
console.log(c);   //打印为100
}
fn();
console.log(c);     //打印为undefined
   var c = 100;
   console.log(c);   //打印为100
function fn(){
console.log(c);   //打印为undefined;自己函数体类的变量声明提升
    var c = 20;        
console.log(c);   //打印为20,自己函数体内有变量c,就近原则,使用自己函数体内的变量
}
fn();

console.log(d);     //打印为undefined
   var d = 100;
   console.log(d);   //打印为100
function fn(){
console.log(d);   //打印为100
     d = 20;        //定义的为隐式全局变量
console.log(d);   //打印为20
}
fn();

console.log(a);     //打印为undefined
   var a = 100;
   console.log(a);   //打印为100
function fn(){
console.log(a);   
     a = 20;        //定义的为隐式全局变量
console.log(a);   
}
console.log(a);  //打印为100
fn();    //在执行该语句时打印首先打印的是100(隐式变量声明未提升,首先该语句执行时之前没有找变量就从全局找)和
         //20(从自己的中找到个隐式全局变量d,所以打印为20)
console.log(a) //打印为20(函数数体中的隐式全局变量覆盖了外部的变量)

console.log(a);     //打印为undefined
   var a = 100;
   console.log(a);   //打印为100
fn();    //在执行该语句时打印首先打印的是100(隐式变量声明未提升,首先该语句执行时之前没有找变量就从全局找)和
         //20(从自己的中找到个隐式全局变量d,所以打印为20)
console.log(a); // 打印20,被100值被覆盖function fn(){console.log(a); a = 20; //定义的为隐式全局变量console.log(a); }console.log(a); //打印为20


重要的是知道原理,不论在怎么变都能够明白

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值