JavaScript运行过程中的“预编译阶段”和“执行阶段”


Posted in Javascript onDecember 16, 2015

 javascript相对于其它语言来说是一种弱类型的语言,在其它如java语言中,程序的执行需要有编译的阶段,而在javascript中也有类似的“预编译阶段”(javascript的预编译是以代码块为范围<script></script>,即每遇到一个代码块都会进行  预编译>执行),了解javascript引擎的执行机理,将有助于在写js代码过程中的思路总结

首先科普下javascript中的两种声明方式,var和function,前者声明的是变量,后者声明的是方法

在预编译中,javascript对这两种声明做出了两种处理方案

<script>
var a = "1";

//声明变量a
 function b(){

//声明方法b
  
alert();

}

var c = function(){ //声明变量c


alert();

}
</script>

以上代码块中,a、c为变量赋值,b为函数声明,当执行以上的代码时,首先会进入预编译阶段,对与变量赋值a、c会在内存中开辟一块内存空间并指向变量名,且赋值为undefined

对于函数声明,则同样会进行开辟内存空间,但赋值的对象会将声明的函数赋值给函数名

预编译阶段:(PS:不管代码中声明变量和声明函数的顺序如何,在预编译阶段会先声明变量,再声明函数)

<script>

var a = undefined;


var c = undefined;

 

var b = function(){



alert();


} </script>

 执行阶段:

<script>

a = "1";


c = function(){



alert();


}
</script>

整体执行步骤:

<script>

var a = undefined;


var c = undefined;





var b = function(){



alert();


}


a = "1";


c = function(){



alert();


}
</script>

题目:

<script>

var a = "1";


function b(){



alert(a);



var a = "2";


}


b();
</script>

ps:javascript的预编译

     一、先预定义变量,再预定义函数

二、变量的预编译只作声明,不作初始化,初始化在执行时

 

三、function语句定义的函数,不仅声明了函数名,而且函数体也进行了处理

四、匿名函数不会预编译

function f(){      // 声明函数f  
return 1; } alert(f());       // 返回1 
var f = function(){    // 定义匿名函数f  
return 2; } alert(f());       // 返回2

先预定义了变量f,然后同名函数f()覆盖了变量f,所以第一次输出1;变量的预编译

var f = function(){    // 定义匿名函数f  
return 1; } 
alert(f());       // 返回1 
function f(){      // 声明函数f  
return 2; } 
alert(f());      // 返回1

先预定义了变量f,然后同名函数f()覆盖了变量f.

Javascript 相关文章推荐
Javascript中的常见排序算法
Mar 27 Javascript
AJAX架构之Dojo篇
Apr 10 Javascript
document.compatMode的CSS1compat使用介绍
Apr 03 Javascript
关于javascript模块加载技术的一些思考
Nov 28 Javascript
node.js中的fs.rmdirSync方法使用说明
Dec 16 Javascript
深入理解JavaScript系列(25):设计模式之单例模式详解
Mar 03 Javascript
chrome调试javascript详解
Oct 21 Javascript
JS HTML5拖拽上传图片预览
Jul 18 Javascript
微信小程序中进行地图导航功能的实现方法
Jun 29 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
Aug 20 Javascript
Ajax是什么?Ajax高级用法之Axios技术
Apr 21 Javascript
WebRTC记录音视频流(web技术分享)
Feb 24 Javascript
Sublime Text 3常用插件及安装方法
Dec 16 #Javascript
基于MVC4+EasyUI的Web开发框架形成之旅之界面控件的使用
Dec 16 #Javascript
基于JavaScript获取鼠标位置的各种方法
Dec 16 #Javascript
javascript基于prototype实现类似OOP继承的方法
Dec 16 #Javascript
javascript数组克隆简单实现方法
Dec 16 #Javascript
Perl Substr()函数及函数的应用
Dec 16 #Javascript
javascript针对不确定函数的执行方法
Dec 16 #Javascript
You might like
解决了Ajax、MySQL 和 Zend Framework 的乱码问题
2009/03/03 PHP
解决文件名解压后乱码的问题 将文件名进行转码的代码
2012/01/10 PHP
关于二级目录拖拽排序的实现(源码示例下载)
2013/04/26 PHP
phpExcel中文帮助手册之常用功能指南
2014/08/18 PHP
从零开始学YII2框架(二)通过 Composer 安装扩展插件
2014/08/20 PHP
Zend Framework常用校验器详解
2016/12/09 PHP
javascrip关于继承的小例子
2013/05/10 Javascript
js字母大小写转换实现方法总结
2013/11/13 Javascript
JQuery+Ajax无刷新分页的实例代码
2014/02/08 Javascript
js换图片效果可进行定时操作
2014/06/09 Javascript
JavaScript点击按钮后弹出透明浮动层的方法
2015/05/11 Javascript
js判断日期时间有效性的方法
2015/10/24 Javascript
学习JavaScript设计模式之策略模式
2016/01/12 Javascript
JavaScript中对JSON对象的基本操作示例
2016/05/21 Javascript
Node.js中的http请求客户端示例(request client)
2017/05/04 Javascript
vue-cli如何引入bootstrap工具的方法
2017/10/19 Javascript
用vue快速开发app的脚手架工具
2018/06/11 Javascript
javascript 构建模块化开发过程解析
2019/09/11 Javascript
[01:00]DOTA2 store: Collection of Artisan's Wonders
2015/08/12 DOTA
python判断、获取一张图片主色调的2个实例
2014/04/10 Python
Python列出一个文件夹及其子目录的所有文件
2016/06/30 Python
Django-Rest-Framework 权限管理源码浅析(小结)
2018/11/12 Python
Python之——生成动态路由轨迹图的实例
2019/11/22 Python
Jupyter notebook设置背景主题,字体大小及自动补全代码的操作
2020/04/13 Python
详解使用Python写一个向数据库填充数据的小工具(推荐)
2020/09/11 Python
python Matplotlib数据可视化(1):简单入门
2020/09/30 Python
python+flask编写一个简单的登录接口
2020/11/13 Python
详解CSS 3 中的 calc() 方法
2018/01/12 HTML / CSS
美国隐形眼镜网上商店:Lens.com
2019/09/03 全球购物
地理科学专业毕业生求职信
2013/10/15 职场文书
保险公司开门红口号
2014/06/21 职场文书
2014年教师节活动总结
2014/08/29 职场文书
北京英语导游词
2015/02/12 职场文书
2015年五一劳动节演讲稿
2015/03/18 职场文书
师范生小学见习总结
2015/06/23 职场文书
pandas DataFrame.shift()函数的具体使用
2021/05/24 Python