JavaScript运行过程中的“预编译阶段”和“执行阶段”
作者:bea
javascript相对于其它语言来说是一种弱类型的语言,在其它如java语言中,程序的执行需要有编译的阶段,而在javascript中也有类似的“预编译阶段”(javascript的预编译是以代码块为范围<script></script>,即每遇到一个代码块都会进行 预编译>执行),了解javascript引擎的执行机理,将有助于在写js代码过程中的思路总结 首先科普下javascript中的两种声明方式,var和function,前者声明的
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.
猜你喜欢
您可能感兴趣的文章:
- 详解js图片轮播效果实现原理
- js和jquery分别验证单选框、复选框、下拉框
- jQuery+CSS实现滑动的标签分栏切换效果
- JS禁用页面上所有控件的实现方法(附demo源码下载)
- jQuery选择器用法实例详解
- 深入分析jQuery的ready函数是如何工作的(工作原理)
- js倒计时简单实现方法
- 高效的jquery数字滚动特效
- JS函数的几种定义方式分析
- js实现文字闪烁特效的方法
- 基于jquery实现省市联动特效
- js实现网页收藏功能
- 详解javascript中原始数据类型Null和Undefined
- JS实现合并两个数组并去除重复项只留一个的方法
- JS数组合并push与concat区别分析
- 理解Javascript的call、apply
- javascript实现网站加入收藏功能
- javascript实现无缝上下滚动特效
- js实现将选中内容分享到新浪或腾讯微博