Javascript预编译和执行过程

之前一直使用javascript,但是对javascript的执行过程不太了解。今天网上看到一篇文章,感觉写得很好,分享给大家。

原文出处:http://www.cnblogs.com/zhangjh/articles/1895472.html#commentform

1. 在执行前会进行类似“预编译”的操作:首先会创建一个当前执行环境下的活动对象,并将那些用var申明的变量设置为活动对象的属性,但是此时这些变量的赋值都是undefined,并将那些以function定义的函数也添加为活动对象的属性,而且它们的值正是函数的定义。

2.在解释执行阶段,遇到变量需要解析时,会首先从当前执行环境的活动对象中查找,如果没有找到而且该执行环境的拥有者有prototype属性时则会从prototype链中查找,否则将会按照作用域链查找。遇到var a = ...这样的语句时会给相应的变量进行赋值(注意:变量的赋值是在解释执行阶段完成的,如果在这之前使用变量,它的值会是undefined)


根据以上说明的一些测试:

<script type="text/javascript">
alert(myName); //undefined 
var myName = "hong"; 
alert(myName); //hong 
</script>

<script type="text/javascript">
func(); //hello
function func(){
  alert("hello!")
}
</script>

<script type="text/javascript">
/*在预编译过程中func是window环境下的活动对象中的一个属性,值是一个函数,覆盖了undefined值*/
alert(func); //function func
var func = "this is a variable"
function func(){
  alert("hello!")
}
/*在执行过程中遇到了var重新赋值为"this is a variable"*/
alert(func); //this is a variable
</script>

<script type="text/javascript">
var name = "hong";
function func(){
  /*首先,在func环境内先把name赋值为undefined,然后在执行过程中先寻找func环境下的活动对象的name属性,此时之前已经预编译值为undefined,所以输出是undefined,而不    是hong*/
  alert(name); //undefined
  var name = "JSF";
  alert(name); //JSF
}
func();
alert(name); //hong
</script>


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值