码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-12-16 14:06:42      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:

javascript相对于其它语言来说是一种弱类型的语言,在其它如java语言中,程序的执行需要有编译的阶段

而在javascript中也有类似的“预编译阶段”(javascript的预编译是以代码块为范围<script></script>,即每遇到一个代码块都会进行  预编译>执行),

 

首先科普下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:相对与window环境下的变量、函数声明,每一个作用域都会对其下的变量和函数进行先声明

<script>      
  functionHello() {        
    alert("Hello");       
  }        
  Hello();  
</script>   
<script>   
  functionHello() {          
    alert("Hello World");     
  }       
  Hello();  
</script>
<script>   
  function Hello() {        
    alert("Hello");       
  }        
  Hello(); 
  function Hello() {          
    alert("Hello World");     
  }       
  Hello();  
</script>

 

博客:http://www.cnblogs.com/alex-web/

注:小疯纸的yy

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

标签:

原文地址:http://www.cnblogs.com/alex-web/p/5048390.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!