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

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

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

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

<script>
  vara = "1";    //声明变量a
 functionb(){    //声明方法b
    alert();
  }
  varc = function(){//声明变量c
    alert();
  }
</script>


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

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

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

<script>
    vara = undefined;
    varc = undefined;         varb = function(){
      alert();
    } </script>


 执行阶段:

<script>
    a = "1";
    c = function(){
      alert();
    }
</script>


整体执行步骤:

<script>
    vara = undefined;
    varc = undefined;
    
    varb = function(){
      alert();
    }
    a = "1";
    c = function(){
      alert();
    }
</script>


题目:

<script>
    vara = "1";
    functionb(){
      alert(a);
      vara = "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.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值