变量提升与预解析

js预析

三个要素:

  1. var
  2. 方法参数
  3. function

预解析过程就是变量提升的过程,每当出现这三要素之一,首先形成预先解析空间,预解析完成以后,再逐行执行。
如果在本作用域中没有找到值得定义,那么将会向上查找,形成作用域链

什么是作用域?
个人理解:一段解析空间

配合题目加深理解:

console.log(a)
var a = 1;
console.log(a)
function a(){
    console.log(1)
}
var a = 2;
console.log(a)
function a(){
    console.log(2)
}
function a(){
    console.log(3)
}
a()
console.log(a);

根据规则,先与解析,再逐行执行,实际预解析结果如下:

// 看三要素:var 方法参数 function
// 遇到第一个var
a = undefined
// 遇到第一个方法a
a = function(){console.log(1)}
// 遇到第二个var
a = undefined
// 遇到第二个方法a
a = function(){console.log(2)}
// 遇到第三个方法a
a = function(){console.log(3)}
// 后面没有其他得要素了 ,预解析结束

再逐行执行,结果如下:

 console.log(a) // function(){console.log(3)}
 var a = 1;  // 赋值1
 console.log(a)  // 1
 function a(){console.log(1)} // 声明方法a 跳过不执行
 var a = 2; // 赋值2
 console.log(a)  // 2
 function a(){console.log(2)} // 声明方法a 跳过不执行
 function a(){console.log(3)} // 声明方法a 跳过不执行
 a()  // a此时是值2,不是方法,报错, a is not function
 console.log(a) // 2
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值