作家
登录

JS声明变量背后的编译原理剖析

作者: 来源:www.28hudong.com 2013-03-30 00:16:09 阅读 我要评论

只要是写过点JS代码,很简单一个var 就完事了。那对于JS编译器背后它又发生了什么呢?那就一步步通过代码来讲起。 复制代码 代码如下: x = 1; alert(x); var y = function() { alert(x); var x = 2; alert(x); } y(); 上面的代码也会你答对了它会分别输出:1,undefined,2。对于我来说,第一反应它会输出:1,1,2。为什么第二个会输出undefined?在上面我明确定义了一个全局变量x,为何找不到? 那是因为:js编译器在执行这个y函数的时候,会把把它body里面的声明变量提前到最前面进行声明。比如:var x=2; 编译器先会在body最前面进行var x 声明。其实上面的代码等同于下面的这段代码: 复制代码 代码如下: x = 1; alert(x); var y = function() {<BR>var x;//此时x还未赋值,所以为undefined。 alert(x); x = 2; alert(x); } y(); 所以也就不难理解x=undefined的了.但是如果把var x = 2;这段代码给删掉,在内部它没有进行var声明。它会一直沿着作用域向上找,此时的x 就为全局x. 接下来再看一个更有趣的例子。 复制代码 代码如下: var a = 1; function b() { a = 10; return; } b(); alert(a); /////////////////////////////////// var a = 1; function b() { a = 10; return; function a() {} } b(); alert(a); 例子很简单。第一个例子为输出10,第二个会输出1。这是为什么呢?况且第二个例子我都return 了。按理都应当输出10才对呀!那时因为JS编译器在背后作怪。 两段代码差别就是第二个例子多了个function a(){};便这个函数体里面什么也没有,并且也没有对它进行任何调用。其实JS编译器在背后会把function a() {}编译成 var a=function (){}。此时对于函数内部也有一个a=10; 外面的a些也还是1;根据JS作用域。会先找内部的a,如果找不到再向上一级一级找。 最张alert(a) 就会显示1;

  推荐阅读

  JSON为什么那样红为什么要用json(另有洞天)

json是1年内迅速红遍全球的东东。 现在解释JSON是什么,大家都会说我老土吧,这里我想分析一下json红的原因,我们又得到什么启示呢。 json是什么,json.org是一种简洁有效的数据载体,是一种用字符串表示复杂js对象>>>详细阅读


本文标题:JS声明变量背后的编译原理剖析

地址:http://www.17bianji.com/kaifa2/JS/22695.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)