重拾JS-11-预解析

本文详细探讨了JavaScript引擎的执行过程,包括预解析阶段和代码执行阶段。通过分析不同代码示例,揭示了变量提升和函数声明的处理方式,特别是对于变量和函数的作用域影响。理解这些概念有助于避免常见的JS运行时错误。
摘要由CSDN通过智能技术生成

目标:解决以下问题

  • 能够知道解析器运行JS分为那两步

思路引导

   //坑1
     console.log(num);//报错
    //坑2
    console.log(num);//undefined
    var num=4;
    //坑3
    fn();//正常输出:嘟嘟嘟
    function fn(){
        console.log('嘟嘟嘟');
    }
    //坑4
    fun();//报错
    var fun=function(){
        console.log('新垣结衣结婚了啊');
    }

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

  • 预解析:JS引擎会把js里面所有var还有function提升到当前作用域的最前面
  • 代码执行:按照代码书写顺序执行
预解析案例分析:

案例1:

  //案例1
    var num=10;
    function fn(){
        var num=30;
        console.log(num);
    }
    fn();//输出30

    //JS引擎执行顺序如下
    var num;
    function fn(){
        var num=30;
        console.log(num);
    }
    num=10;
    fn();

案例2:

    //案例2
    var num=10;
    function fn(){
        console.log(num);
        var num=20;
        console.log(num);
    }
    fn();//输出undefined和20

    //JS引擎执行顺序如下
    var num;
    function fn(){
        var num;
        console.log(num);
        num=20;
        console.log(num);
    }
    num=10;
    fn();

案例3:

   //案例3
    fn();
    console.log(c);
    console.log(b);
    console.log(a);
    function fn(){
        var a=b=c=9;//相当于var a=9;b=9;c=9;  b和c相当于全局变量
        console.log(a);
        console.log(b);
        console.log(c);
    }
//输出5个9,第六行报错

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值