JavaScript学习笔记(六)预解析

本文深入探讨JavaScript引擎的工作原理,重点解析预解析和代码执行两个阶段。预解析包括变量提升和函数提升,其中变量只提升声明而不提升赋值,函数则整个声明被提升。通过示例解释了变量和函数提升的规则,并通过一个函数执行的例子展示了变量初始化和作用域的影响。
摘要由CSDN通过智能技术生成

1. js引擎运行js分两步:预解析,代码执行

(1)预解析:js引擎把js里所有的var和function提升到当前作用域的最前面

(2)代码执行:按照代码书写顺序进行执行

2. 预解析分为:变量预解析(变量提升)和函数预解析(函数提升)

(1)变量提升,把所有变量声明提升到作用域最前面,但是不提升赋值操作

(2)函数提升,就是把所有函数声明提升到当前作用域的最前面,不调用函数

如:

        fun()

        var fun = function(){

            console.log(00)

        }//出错

        //相当于执行了

        var fun

        fun()

        fun = function(){

            console.log(00)

        }

 一个执行例子

        function f1(){
            var a=b=c=10;  //相当于是var a=10;b=10;c=10        bc是全局变量
            console.log(a)
            console.log(b)
            console.log(c)
        }
        f1()
        console.log(c)
        console.log(b)
        console.log(a)

结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值