js的预编译

JavaScript代码在js引擎中的运行过程:
第一步:语法分析,就是引擎检查你的代码有没有什么低级的语法错误 。
第二步:预编译,预编译简单理解就是在内存中开辟一些空间,存放一些变量与函数 。
第三步:解释执行,解释执行顾名思义便是执行代码。

预编译分为全局预编译和局部预编译。

全局:

第一步:创建GO对象(Gloabl Object全局对象) 在窗口打开时创建
第二步:所有全局变量声明整体提升,值为undefined。
第三步:所有函数声明(不是表达式!)整体提升,值为函数体。如果变量和函数名称相同,函数将会覆盖掉变量的值。
全局变量:全局变量的声明有两种方式
1.显示声明:
使用var(关键字)+变量名(标识符)的方式在function外部声明,即为全局变量,否则在function声明的是局部变量.
2.隐式声明:
没有使用var,直接给变量赋值,这样会隐式的声明了全局变量。即使该语句是在一个function内,当该function被执行后这个变量就变成了全局变量。

局部:

第一步:创建AO对象(Active Object活动对象),在函数(function)执行的前一刻的时候创建
第二步:函数体内所有变量声明整体提升,值为undefined(注意:形参也属于变量声明)
第三步:使形参、实参值相对应,也就是把实参的值赋给性参
第四步:所有函数声明(不是表达式!)整体提升,值为函数体。如果变量和函数名称相同,函数将会覆盖掉变量的值

函数在执行的前一刻的时候会产生一个执行期上下文,一个执行期上下文所对应的是一个函数在执行期间的环境,每个执行期上下文都是独一无二的,在函数执行结束之后,所对应的执行期上下文就会被销毁,多次调用同一个函数,会产生多个不同的执行期上下文。
例:在这里插入图片描述

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值