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入门教程(3) js面向对象
Jan 31 Javascript
Jquery:ajax实现翻页无刷新功能代码
Aug 05 Javascript
node.js读取文件到字符串的方法
Jun 29 Javascript
jQuery实现网页抖动的菜单抖动效果
Aug 07 Javascript
PHP抓取HTTPS内容和错误处理的方法
Sep 30 Javascript
深入理解JavaScript 参数按值传递
May 24 Javascript
浅谈 Vue 项目优化的方法
Dec 16 Javascript
mpvue构建小程序的方法(步骤+地址)
May 22 Javascript
小程序页面动态配置实现方法
Feb 05 Javascript
vue子传父关于.sync与$emit的实现
Nov 05 Javascript
js实现手表表盘时钟与圆周运动
Sep 18 Javascript
前端vue+elementUI如何实现记住密码功能
Sep 20 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
PHP 数组排序方法总结 推荐收藏
2010/06/30 PHP
PHP cdata 处理(详细介绍)
2013/07/05 PHP
PHP闭包实例解析
2014/09/08 PHP
PHP按指定键值对二维数组进行排序的方法
2015/12/22 PHP
php生成图片缩略图功能示例
2017/02/22 PHP
详谈phpAdmin修改密码后拒绝访问的问题
2017/04/03 PHP
实例介绍PHP删除数组中的重复元素
2019/03/03 PHP
JavaScript类属性的访问方式详解
2014/02/11 Javascript
页面加载完后自动执行一个方法的js代码
2014/09/06 Javascript
JavaScript修改作用域外变量的方法
2016/03/25 Javascript
jQuery插件制作的实例教程
2016/05/16 Javascript
js小数计算小数点后显示多位小数的实现方法
2016/05/30 Javascript
Bootstrap和Angularjs配合自制弹框的实例代码
2016/08/24 Javascript
JS遍历对象属性的方法示例
2017/01/10 Javascript
BootStrap selectpicker后台动态绑定数据
2017/06/01 Javascript
JS创建Tag标签的方法详解
2017/06/09 Javascript
echarts鼠标覆盖高亮显示节点及关系名称详解
2018/03/17 Javascript
JS/HTML5游戏常用算法之路径搜索算法 A*寻路算法完整实例
2018/12/14 Javascript
jQuery实现中奖播报功能(让文本滚动起来) 简单设置数值即可
2020/03/20 jQuery
使用Python简单的实现树莓派的WEB控制
2016/02/18 Python
简单谈谈Python中的反转字符串问题
2016/10/24 Python
django允许外部访问的实例讲解
2018/05/14 Python
python matplotlib画盒图、子图解决坐标轴标签重叠的问题
2020/01/19 Python
Python Tkinter Entry和Text的添加与使用详解
2020/03/04 Python
First Aid Beauty官网:FAB急救面霜
2018/05/24 全球购物
Made in Design英国:设计家具、照明、家庭装饰和花园家具
2019/09/24 全球购物
大学生预备党员自我评价分享
2013/11/16 职场文书
小学教师师德师风演讲稿
2014/08/22 职场文书
捐助倡议书
2015/01/19 职场文书
巴黎圣母院观后感
2015/06/10 职场文书
一年级语文教学随笔
2015/08/14 职场文书
家长对孩子的寒假评语
2015/10/09 职场文书
2019消防宣传标语!
2019/07/10 职场文书
800字作文之大雪
2019/12/04 职场文书
Mysql外键约束的创建与删除的使用
2022/03/03 MySQL
Spring Boot项目如何优雅实现Excel导入与导出功能
2022/06/10 Java/Android