题目有点大,其实也就是手痒。。。跟大家来扯一下javascript编译过程。
这个。。。本人文笔太差,我还是直接举例子吧。
相信玩过js童鞋应该都看过下面这样一个面试题:
var a=3;
function fn(){ alert(a); function a(){ a=5; }
a();
alert(a);
}
fn();
alert(a);
请问上面的题目执行结果如何呢?
各位童鞋都听过js是一门解释型语言。什么不知道“解释型语言”是啥。。。
“解释型语言”,通俗点说就是指从上往读一行执行一行。什么还是不知道。。。出门左拐 百度百科。
不错,js确实是一门解释型语言。但是,他是“有编译的”解释执行。
什么叫“有编译”,其实就是在执行前是先对整个程序进行整理(其他语言则是通过编译将源代码整理出目标程序)。
下面我们来看一下js的编译过程到底是怎么样的呢;
就拿上面这个例子来说吧:
a();
alert(a);
}
active.a=a=3;//赋值
active.fn();//执行函数】
fnActive={a:3}//已存在变量直接引用了外层的active;
fnActive.a=function{
a=5;
}
alert(a);//这时候a是啥啊。。。大家应该知道吧。相当于 alert(fnActive.a);
a();运行到这一步以后fnActive.a=5了
后面 运行 alert(a); 这里相当于 alert(fnActive.a=5);相信答案已经很明确了
最后是。最外层那个 alert(a);了 那么值到底是哪一个呢 由于 fn()这个方法里面操作的其实不是active.a这个值 所以a的值一直没有改变
这里不明确给出答案。只是希望大家自己去试验
我也来谈javascript高级编程之:javascript函数编译过程,布布扣,bubuko.com
我也来谈javascript高级编程之:javascript函数编译过程
原文:http://www.cnblogs.com/tomblog/p/3281961.html