实例讲解JavaScript预编译流程


Posted in Javascript onJanuary 24, 2019

大家都知道JavaScript是解释型语言,既然是解释型语言,就是编译一行,执行一行,那又何来预编译一说呢?脚本执行js引擎都做了什么呢?今天我们就来看看吧。

1-JavaScript运行三部曲

语法分析

预编译

解释执行

语法分析很简单,就是引擎检查你的代码有没有什么低级的语法错误; 解释执行顾名思义便是执行代码了; 预编译简单理解就是在内存中开辟一些空间,存放一些变量与函数 ;

2-JS预编译什么时候发生

预编译到底什么时候发生? 误以为预编译仅仅发生在script内代码块执行前 这倒并没有错 预编译确确实实在script代码内执行前发生了 但是它大部分会发生在函数执行前

3-实例分析

先来区分理解一下这2个概念: 变量声明 var ... 函数声明 function(){}

<script>
var a = 1;
console.log(a);
function test(a) {
 console.log(a);
 var a = 123;
 console.log(a);
 function a() {}
 console.log(a);
 var b = function() {}
 console.log(b);
 function d() {}
}
var c = function (){
console.log("I at C function");
}
console.log(c);
test(2);
</script>

分析过程如下:

页面产生便创建了GO全局对象(Global Object)(也就是window对象);

第一个脚本文件加载;

脚本加载完毕后,分析语法是否合法;

开始预编译 查找变量声明,作为GO属性,值赋予undefined; 查找函数声明,作为GO属性,值赋予函数体;

预编译

//抽象描述
  GO/window = {
    a: undefined,
    c: undefined,
    test: function(a) {
      console.log(a);
      var a = 123;
      console.log(a);
      function a() {}
      console.log(a);
      var b = function() {}
      console.log(b);
      function d() {}
    }
  }

解释执行代码(直到执行调用函数test(2)语句)

//抽象描述
  GO/window = {
    a: 1,
    c: function (){
      console.log("I at C function");
    }
    test: function(a) {
      console.log(a);
      var a = 123;
      console.log(a);
      function a() {}
      console.log(a);
      var b = function() {}
      console.log(b);
      function d() {}
    }
  }

执行函数test()之前,发生预编译
创建AO活动对象(Active Object);

查找形参和变量声明,值赋予undefined;

实参值赋给形参;

查找函数声明,值赋予函数体;

预编译之前面1、2两小步如下:

//抽象描述
  AO = {
    a:undefined,
    b:undefined,
  }

预编译之第3步如下:

//抽象描述
    AO = {
      a:2,
      b:undefined,
    }

预编译之第4步如下:

//抽象描述
  AO = {
    a:function a() {},
    b:undefined
    d:function d() {}
  }

执行test()函数时如下过程变化:

//抽象描述
  AO = {
    a:function a() {},
    b:undefined
    d:function d() {}
  }
  --->
  AO = {
    a:123,
    b:undefined
    d:function d() {}
  }
  --->
  AO = {
    a:123,
    b:function() {}
    d:function d() {}
  }

执行结果:

实例讲解JavaScript预编译流程

注意:

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

预编译(函数执行前)

创建AO对象(Active Object)

查找函数形参及函数内变量声明,形参名及变量名作为AO对象的属性,值为undefined

实参形参相统一,实参值赋给形参

查找函数声明,函数名作为AO对象的属性,值为函数引用

预编译(脚本代码块script执行前)
查找全局变量声明(包括隐式全局变量声明,省略var声明),变量名作全局对象的属性,值为undefined

查找函数声明,函数名作为全局对象的属性,值为函数引用

预编译小结

预编译两个小规则

函数声明整体提升-(具体点说,无论函数调用和声明的位置是前是后,系统总会把函数声明移到调用前面)

变量 声明提升-(具体点说,无论变量调用和声明的位置是前是后,系统总会把声明移到调用前,注意仅仅只是声明,所以值是undefined)

预编译前奏

imply global 即任何变量,如果未经声明就赋值,则此变量就位全局变量所有。(全局域就是Window)

一切声明的全局变量,全是window的属性; var a = 12;等同于Window.a = 12;

函数预编译发生在函数执行前一刻。

Javascript 相关文章推荐
formValidator3.3的ajaxValidator一些异常分析
Jul 12 Javascript
JavaScript中的null和undefined解析
Apr 14 Javascript
jQuery中json对象的复制方式介绍(数组及对象)
Jun 08 Javascript
jquery 简单应用示例总结
Aug 09 Javascript
用js实现in_array的方法
Nov 05 Javascript
Jquery创建一个层当鼠标移动到层上面不消失效果
Dec 12 Javascript
用js设置下拉框为只读的小技巧
Apr 10 Javascript
jQuery ajax请求返回list数据动态生成input标签,并把list数据赋值到input标签
Mar 29 Javascript
总结十个Angular.js由浅入深的面试问题
Aug 26 Javascript
easyui combobox开启搜索自动完成功能的实例代码
Nov 08 Javascript
Bootstrap CSS使用方法
Dec 23 Javascript
小程序关于请求同步的总结
May 05 Javascript
实例讲解vue源码架构
Jan 24 #Javascript
详解Node.js amqplib 连接 Rabbit MQ最佳实践
Jan 24 #Javascript
JavaScript私有变量实例详解
Jan 24 #Javascript
小程序从手动埋点到自动埋点的实现方法
Jan 24 #Javascript
JavaScript递归函数定义与用法实例分析
Jan 24 #Javascript
jQuery实现当拉动滚动条到底部加载数据的方法分析
Jan 24 #jQuery
vue结合element-ui使用示例
Jan 24 #Javascript
You might like
Discuz!下Memcache缓存实现方法
2010/05/28 PHP
一道关于php变量引用的面试题
2010/08/08 PHP
Yii核心组件AssetManager原理分析
2014/12/02 PHP
php检测apache mod_rewrite模块是否安装的方法
2015/03/14 PHP
PHP对象克隆clone用法示例
2016/09/28 PHP
PHP的消息通信机制测试实例
2016/11/10 PHP
PHP解密支付宝小程序的加密数据、手机号的示例代码
2021/02/26 PHP
Javascript typeof 用法
2008/12/28 Javascript
Javascript 日期对象Date扩展方法
2009/05/30 Javascript
IE 下的只读 innerHTML
2009/08/21 Javascript
jquery 批量上传图片实现代码
2010/01/28 Javascript
精通Javascript系列之数值计算
2011/06/07 Javascript
JS下拉框内容左右移动效果的具体实现
2013/07/10 Javascript
JS将数字转换成三位逗号分隔的样式(示例代码)
2014/02/19 Javascript
JQuery中DOM加载与事件执行实例分析
2015/06/13 Javascript
js 获取元素所有兄弟节点的实现方法
2016/09/06 Javascript
微信小程序开发(一) 微信登录流程详解
2017/01/11 Javascript
svg动画之动态描边效果
2017/02/22 Javascript
js实现悬浮窗效果(支持拖动)
2017/03/09 Javascript
常用的js方法合集
2017/03/10 Javascript
浅析bootstrap原理及优缺点
2017/03/19 Javascript
bootstrap Table插件使用demo
2017/08/07 Javascript
vue.js模仿京东省市区三级联动的选择组件实例代码
2017/11/22 Javascript
Angular6新特性之Angular Material
2018/12/28 Javascript
Node.js中Koa2在控制台输出请求日志的方法示例
2019/05/02 Javascript
js实现弹幕飞机效果
2020/08/27 Javascript
python实现的udp协议Server和Client代码实例
2014/06/04 Python
分享PyCharm最新激活码(真永久激活方法)不用每月找安装参数或最新激活码了
2020/12/27 Python
CSS3 中的@keyframes介绍
2014/09/02 HTML / CSS
JD Sports比利时官网:英国领先的运动鞋和运动服饰零售商
2018/10/10 全球购物
介绍Java的内部类
2012/10/27 面试题
信访工作者先进事迹
2014/01/17 职场文书
安全事故检讨书
2014/01/18 职场文书
《索溪峪的野》教学反思
2016/02/19 职场文书
浅谈由position属性引申的css进阶讨论
2021/05/25 HTML / CSS
JavaScript实现登录窗体
2021/06/22 Javascript