实例讲解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 相关文章推荐
超级强大的表单验证
Jun 26 Javascript
javascript addBookmark 加入收藏 多浏览器兼容
Aug 15 Javascript
js原生态函数中使用jQuery中的 $(this)无效的解决方法
May 25 Javascript
JQuery拖动表头边框线调整表格列宽效果代码
Sep 10 Javascript
简介alert()与console.log()的不同
Aug 26 Javascript
JS基于Ajax实现的网页Loading效果代码
Oct 27 Javascript
javascript函数中的3个高级技巧
Sep 22 Javascript
layui中layer前端组件实现图片显示功能的方法分析
Oct 13 Javascript
js实现鼠标移动到图片产生遮罩效果
Oct 21 Javascript
React 组件渲染和更新的实现代码示例
Feb 21 Javascript
JS实现电商商品展示放大镜特效
Jan 07 Javascript
Vue-cli3多页面配置详解
Mar 22 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
Windows IIS PHP 5.2 安装与配置方法
2009/06/08 PHP
第四章 php数学运算
2011/12/30 PHP
CI(CodeIgniter)框架中的增删改查操作
2014/06/10 PHP
Twig模板引擎用法入门教程
2016/01/20 PHP
Zend Framework教程之Zend_Db_Table用法详解
2016/03/21 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
简单谈谈PHP中的trait
2017/02/25 PHP
简单实现php上传文件功能
2017/09/21 PHP
PHP中PDO事务处理操作示例
2018/05/02 PHP
php设计模式之职责链模式实例分析【星际争霸游戏案例】
2020/03/27 PHP
JS版网站风格切换实例代码
2008/10/06 Javascript
javascript中的107个基础知识收集整理 推荐
2010/03/29 Javascript
IE8的JavaScript点击事件(onclick)不兼容的解决方法
2013/11/22 Javascript
jquery 操作css样式、位置、尺寸方法汇总
2014/11/28 Javascript
jquery文档操作wrap()方法实例简述
2015/01/10 Javascript
cocos2dx骨骼动画Armature源码剖析(一)
2015/09/08 Javascript
jQuery 1.9.1源码分析系列(十四)之常用jQuery工具
2015/12/02 Javascript
jquery 重写 ajax提交并判断权限后 使用load方法报错解决方法
2016/01/19 Javascript
微信小程序 swiper组件详解及实例代码
2016/10/25 Javascript
浅析JS抽象工厂模式
2017/12/14 Javascript
Bootstrap Table中的多选框删除功能
2018/07/15 Javascript
socket在egg中的使用实例代码详解
2019/05/30 Javascript
JS深入学习之数组对象排序操作示例
2020/05/01 Javascript
[02:03]永远的信仰DOTA2 中国军团历届国际邀请赛回顾
2016/06/26 DOTA
[32:26]EG vs IG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
django 在原有表格添加或删除字段的实例
2018/05/27 Python
python实现微信每日一句自动发送给喜欢的人
2019/04/29 Python
Python 3.6 中使用pdfminer解析pdf文件的实现
2019/09/25 Python
Python 解码Base64 得到码流格式文本实例
2020/01/09 Python
简述python Scrapy框架
2020/08/17 Python
荷兰网上鞋店:Ziengs.nl
2017/01/02 全球购物
食堂个人先进事迹
2014/01/22 职场文书
2014厂务公开实施方案
2014/02/17 职场文书
建筑公司员工自我鉴定
2014/04/08 职场文书
预备党员对照检查材料思想汇报
2014/09/24 职场文书
HTML+JS实现在线朗读器
2022/02/15 Javascript