JS预解析(变量提升),它导致了什么问题?

JavaScript引擎在执行前会进行预编译,扫描并提升变量和函数声明。这导致了变量提升现象,允许在声明之前访问变量或函数而不报错。解析过程包括创建全局和函数执行上下文,初始化变量为undefined,准备函数执行。作用域链帮助在执行时找到变量。文章强调了解析和执行两个阶段,以及this、arguments在函数上下文中的重要性。
摘要由CSDN通过智能技术生成

JS代码在执行前,浏览器会对js代码进行扫描,

默认的把所有带var和function声明的变量进行提前的声明或者定义,遵循先解析后使用的原则。

变量提升的表现是,在变量或函数声明之前访问变量或调用函数而不会报错。

原因 JavaScript引擎在代码执行前有一个解析的过程(预编译),

创建执行上线文,初始化一些代码执行时需要用到的对象。

当访问一个变量时,会到当前执行上下文中的作用域链中去查找,

而作用域链的首端指向的是当前执行上下文的变量对象,这个变量对象是执行上下文的一个属性,

它包含了函数的形参、所有的函数和变量声明,这个对象的是在代码解析的时候创建的。

首先要知道,JS在拿到一个变量或者一个函数的时候,会有两步操作,即解析和执行。

1.在解析阶段 JS会检查语法,并对函数进行预编译。解析的时候会先创建一个全局执行上下文环境,先把代码中即将执行的变量、函数声明都拿出来, 变量先赋值为undefined,函数先声明好可使用。在一个函数执行之前,也会创建一个函数执行上下文环境,跟全局执行上下文类似, 不过函数执行上下文会多出this、arguments和函数的参数。

全局上下文:变量定义,函数声明 函数上下文:变量定义,函数声明,this,arguments

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值