实例讲解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 相关文章推荐
jQuery中文入门指南,翻译加实例,jQuery的起点教程
Feb 09 Javascript
无语,javascript居然支持中文(unicode)编程!
Apr 12 Javascript
js解析与序列化json数据(一)json.stringify()的基本用法
Feb 01 Javascript
Js获取数组最大和最小值示例代码
Oct 29 Javascript
理解和运用JavaScript的闭包机制
Aug 13 Javascript
拥Bootstrap入怀——导航栏篇
May 30 Javascript
深入理解Angular2 模板语法
Aug 07 Javascript
react-native-tab-navigator组件的基本使用示例代码
Sep 07 Javascript
详解Vuex管理登录状态
Nov 13 Javascript
详解React之父子组件传递和其它一些要点
Jun 25 Javascript
小程序云开发实战小结
Oct 25 Javascript
js打开word文档预览操作示例【不是下载】
May 23 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
桌面中心(三)修改数据库
2006/10/09 PHP
PHP中常用数组处理方法实例分析
2008/08/30 PHP
10个值得深思的PHP面试题
2016/11/14 PHP
Mac系统完美安装PHP7详细教程
2017/06/06 PHP
PHP实现简单用户登录界面
2019/10/23 PHP
doctype后如何获得body.clientHeight的方法
2007/07/11 Javascript
setInterval 和 setTimeout会产生内存溢出
2008/02/15 Javascript
Firefox div高度自适应
2009/04/28 Javascript
国外大牛IE版本检测!现在IE都到9了,IE检测代码
2012/01/04 Javascript
基于jQuery实现多层次的手风琴效果附源码
2015/09/21 Javascript
JS正则子匹配实例分析
2016/12/22 Javascript
jquery封装插件时匿名函数形参和实参的写法解释
2017/02/14 Javascript
详解vue slot插槽的使用方法
2017/06/13 Javascript
把JavaScript代码改成ES6语法不完全指南(分享)
2017/09/10 Javascript
浅谈Node.js爬虫之网页请求模块
2018/01/11 Javascript
浅析Vue 防抖与节流的使用
2019/11/14 Javascript
H5实现手机拍照和选择上传功能
2019/12/18 Javascript
jQuery实现鼠标移入显示蒙版效果
2020/01/11 jQuery
Element实现表格嵌套、多个表格共用一个表头的方法
2020/05/09 Javascript
django如何连接已存在数据的数据库
2018/08/14 Python
python爬取微信公众号文章
2018/08/31 Python
python flask框架实现重定向功能示例
2019/07/02 Python
基于python实现把图片转换成素描
2019/11/13 Python
使用 Python 清理收藏夹里已失效的网站
2019/12/03 Python
django xadmin中form_layout添加字段显示方式
2020/03/30 Python
终于搞懂了Keras中multiloss的对应关系介绍
2020/06/22 Python
Python调用Redis的示例代码
2020/11/24 Python
挪威太阳镜和眼镜网上商城:SmartBuyGlasses挪威
2016/08/20 全球购物
加拿大最大的五金、家居装修和园艺产品商店:RONA
2017/01/27 全球购物
爱游人:Travelliker
2017/09/05 全球购物
Johnston & Murphy官网: 约翰斯顿·墨菲牛津总统鞋
2018/01/09 全球购物
2014年政工师工作总结
2014/12/18 职场文书
幼儿园园务工作总结2015
2015/05/18 职场文书
高中优秀作文(范文)
2019/08/15 职场文书
Matlab如何实现矩阵复制扩充
2021/06/02 Python
java中为什么说子类的构造方法默认访问的是父类的无参构造方法
2022/04/13 Java/Android