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

前端之家收集整理的这篇文章主要介绍了JavaScript运行过程中的“预编译阶段”和“执行阶段”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

  var a = "1";    //声明变量a function b(){    //声明方法b   alert();   }   var c = function(){ //声明变量c     alert();   }

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

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

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

    var a = undefined;     var c = undefined;         var b = function(){       alert();     }

执行阶段: @H_301_3@

    a = "1";     c = function(){       alert();     }

整体执行步骤: @H_301_3@

    var a = undefined;     var c = undefined;          var b = function(){       alert();     }     a = "1";     c = function(){       alert();     }

题目: @H_301_3@

    var a = "1";     function b(){       alert(a);       var a = "2";     }     b();

ps:javascript的预编译

@H_301_3@

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

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

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

  四、匿名函数不会预编译@H_301_3@

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

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

函数f return 1; } alert(f()); // 返回1 function f(){ // 声明函数f return 2; } alert(f()); // 返回1

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

猜你在找的JavaScript相关文章