JS引擎运行 js 预解析

1 JS引擎运行 js

 我们JS引擎运行js分为两步:预解析 、代码执行。

1.1 预解析

 预解析JS引擎会把js里面所有的var还有function提升到当前作用于的最前面。

  1. 变量提升:就是把所有的变量声明提升到当前作用域的最前面,不提升赋值操作。
  2. 函数提升:就是把所有的函数声明提升到当前作用域的最前面,不调用函数。

1.2 代码执行

 按照代码书写的顺序从上往下执行。

2 代码案例

2.1 第一个案例

 var num=10;
      fun();
      function fun() {
          console.log(num);
          var num=20;
 }
 // 输出为  undefined
 //  相当于以下代码
var num;
function fun() {
    var num;
     console.log(num);
     num=20;
 }
 num=10;
 fun();

2.2 第二个案例

var num;
function fun() {
    console.log(num);
    var num=20;
    console.log(num);
}
fun();
// 输出为 undefined 20

2.3 第三个案例(重点)

面试题 重点

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值