预编译与闭包

预编译

每种计算机都会有自己的编译机制,下面我们就来带代价探讨一下预编译

     js代码在执行前,辉县通篇预览,然后根据自己独有的编译机制进行编译 。
    这就会造成一个问题。变量的声明会提前。就会对代码运行造成影响

预编译什么时候发生

预编译分为全局预编译和局部预编译,全局预编译发生在页面加载完成时执行,而局部预编译发生在函数执行的前一刻。

    tip:预编译阶段发生变量声明和函数声明,没有初始化行为(赋值),
匿名函数不参与预编译 。只有在解释执行阶段才会进行变量初始化 。

js运行三步曲

  1. 语法分析
  2. 预编译
  3. .解释执行

预编译

            首先JavaScript的执行过程会先扫描一下整体语法语句,如果存在逻辑错误或者语法错误,
    那么直接报错,程序停止执行,没有错误的话,开始从上到下解释一行执行一行。

局部预编译的4个步骤:

  1. 创建AO对象(Activation Object)执行期上下文。
  2. 找形参和变量声明,将变量和形参名作为AO属性名,值为undefined
  3. 将实参值和形参统一。
  4. 在函数体里面找函数声明,值赋予函数体。

全局预编译的3个步骤:

  1. List item.创建GO对象(Global Object)全局对象。
  2. 找变量声明,将变量名作为GO属性名,值为undefined
  3. 查找函数声明,作为GO属性,值赋予函数体
    由于全局中没有参数的的概念,所以省去了实参形参相统一这一步。

闭包

闭包是嵌套的内部函数
产生条件:

  1. 要有函数嵌套
  2. 内部函数引用了外部函数的数据
  3. 将函数作为另一个函数返回
  4. 将函数作为实参传递给另一个函数使用

function foo(){
  var local = 1
  function bar(){
    local++
    return local
  }
  return bar
}

var func = foo()
func()

闭包的作用:

  • List item使用函数内部的变量在函数执行好,仍然在内存中
  • 让函数外部可以操作(读取)到函数内部的数据(变量)函数
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值