实例讲解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 相关文章推荐
Javascript isArray 数组类型检测函数
Oct 08 Javascript
JS实现匀速运动的代码实例
Nov 29 Javascript
分享9个最好用的JavaScript开发工具和代码编辑器
Mar 24 Javascript
Jquery中$.post和$.ajax的用法小结
Apr 28 Javascript
微信小程序 特效菜单抽屉效果实例代码
Jan 11 Javascript
js实现滑动到页面底部自动加载更多功能
Feb 15 Javascript
第一次记录Bootstrap table学习笔记(1)
May 18 Javascript
javascript如何用递归写一个简单的树形结构示例
Sep 06 Javascript
详解在Node.js中发起HTTP请求的5种方法
Jan 10 Javascript
在Vue项目中取消ESLint代码检测的步骤讲解
Jan 27 Javascript
微信小程序+云开发实现欢迎登录注册
May 24 Javascript
基于JS实现快速读取TXT文件
Aug 25 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
PHP实现加强版加密解密类实例
2015/07/29 PHP
完美解决php 导出excle的.csv格式的数据时乱码问题
2017/02/18 PHP
thinkPHP5.0框架API优化后的友好性分析
2017/03/17 PHP
PHP长连接实现与使用方法详解
2018/02/11 PHP
用jquery来定位
2007/02/20 Javascript
“不能执行已释放的Script代码”错误的原因及解决办法
2007/09/09 Javascript
js trim函数 去空格函数与正则集锦
2009/11/20 Javascript
原生Js实现元素渐隐/渐现(原理为修改元素的css透明度)
2013/06/24 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
原生JS实现美图瀑布流布局赏析
2015/09/07 Javascript
限制复选框最多选择项的实现代码
2016/05/30 Javascript
Bootstrap文件上传组件之bootstrap fileinput
2016/11/25 Javascript
详解Vue微信公众号开发踩坑全记录
2017/08/21 Javascript
浅谈Vue-cli 命令行工具分析
2017/11/22 Javascript
Vue 开发音乐播放器之歌手页右侧快速入口功能
2018/08/08 Javascript
详解vue项目中使用token的身份验证的简单实践
2019/03/08 Javascript
小程序实现悬浮搜索框
2019/07/12 Javascript
jquery实现垂直无限轮播的方法分析
2019/07/16 jQuery
vue-devtools的安装和使用步骤详解
2019/10/17 Javascript
JS实现打砖块游戏
2020/02/14 Javascript
[51:17]Mineski vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.22
2019/09/05 DOTA
Python引用计数操作示例
2018/08/23 Python
浅谈python 中类属性共享的问题
2019/07/02 Python
python输入错误后删除的方法
2019/10/12 Python
Python抓包程序mitmproxy安装和使用过程图解
2020/03/02 Python
python名片管理系统开发
2020/06/18 Python
Python selenium环境搭建实现过程解析
2020/09/08 Python
HTML5几个设计和修改的页面范例分享
2015/09/29 HTML / CSS
美国从事品牌鞋类零售的连锁店:Famous Footwear
2016/08/25 全球购物
美国开幕式潮店:Opening Ceremony
2018/02/10 全球购物
简述网络文件系统NFS,并说明其作用
2016/10/19 面试题
国外软件测试工程师面试题
2016/12/09 面试题
会计专业应届生求职信
2013/11/24 职场文书
寒假实习自荐信
2014/01/26 职场文书
村主任“四风”问题个人整改措施
2014/10/04 职场文书
2015领导干部廉洁自律工作总结
2015/07/23 职场文书