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 相关文章推荐
Extjs4 关于Store的一些操作(加载/回调/添加)
Apr 18 Javascript
jQuery中prepend()方法使用详解
Aug 11 Javascript
jquery实现顶部向右伸缩的导航区域代码
Sep 02 Javascript
jQuery焦点图轮播插件KinSlideshow用法分析
Jun 08 Javascript
AngularJs定制样式插入到ueditor中的问题小结
Aug 01 Javascript
基于JSON格式数据的简单jQuery幻灯片插件(jquery-slider)
Aug 10 Javascript
AngularJS模块详解及示例代码
Aug 17 Javascript
详解Javascript ES6中的箭头函数(Arrow Functions)
Aug 24 Javascript
Jquery EasyUI $.Parser
Jun 02 jQuery
vue router 传参获取不到的解决方式
Nov 13 Javascript
如何基于javascript实现贪吃蛇游戏
Feb 09 Javascript
vue实现锚点定位功能
Jun 29 Vue.js
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
安健A254立体声随身听的分析与打磨
2021/03/02 无线电
laravel 之 Eloquent 模型修改器和序列化示例
2019/10/17 PHP
jQuery动画效果-fadeIn fadeOut淡入浅出示例代码
2013/08/28 Javascript
jQuery中获取checkbox选中项等操作及注意事项
2013/11/24 Javascript
javascript获取web应用根目录的方法
2014/02/12 Javascript
js和jquery设置disabled属性为true使按钮失效
2014/08/07 Javascript
jQuery简单实现隐藏以及显示特效
2015/02/26 Javascript
Javascript模仿淘宝信用评价实例(附源码)
2015/11/26 Javascript
js学习阶段总结(必看篇)
2016/06/16 Javascript
JS中对数组元素进行增删改移的方法总结
2016/12/15 Javascript
学习使用jQuery表单验证插件和日历插件
2017/02/13 Javascript
JavaScript实现选中文字提示新浪微博分享效果
2017/06/15 Javascript
JavaScript Drum Kit 指南(纯 JS 模拟敲鼓效果)
2017/07/23 Javascript
详解vuex commit保存数据技巧
2018/12/25 Javascript
实例讲解vue源码架构
2019/01/24 Javascript
layui自定义工具栏的方法
2019/09/19 Javascript
vue实现在进行增删改操作后刷新页面
2020/08/05 Javascript
python 随机数生成的代码的详细分析
2011/05/15 Python
Python读写docx文件的方法
2018/05/08 Python
Python 调用 zabbix api的方法示例
2019/01/06 Python
简单了解python PEP的一些知识
2019/07/13 Python
python实现图片,视频人脸识别(opencv版)
2020/11/18 Python
Django利用elasticsearch(搜索引擎)实现搜索功能
2020/11/26 Python
师范生个人推荐信
2013/11/29 职场文书
捐书寄语赠言
2014/01/18 职场文书
交通事故检查书范文
2014/01/30 职场文书
中式婚礼主持词
2014/03/13 职场文书
防邪知识进家庭活动方案
2014/08/26 职场文书
环境工程专业毕业生求职信
2014/09/30 职场文书
营销与策划实训报告
2014/11/05 职场文书
2014年党风廉政建设工作总结
2014/11/19 职场文书
2015年党员干部承诺书
2015/01/21 职场文书
自愿离婚协议书范本
2015/01/26 职场文书
法律意见书范文
2015/05/20 职场文书
网络安全倡议书(3篇)
2019/09/18 职场文书
原生CSS实现文字无限轮播的通用方法
2021/03/30 HTML / CSS