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


Posted in Javascript onDecember 28, 2012

只要是写过点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;

Javascript 相关文章推荐
在textarea中屏蔽js的某个function的javascript代码
Apr 20 Javascript
读jQuery之十四 (触发事件核心方法)
Aug 23 Javascript
js中关于一个分号的崩溃示例
Nov 11 Javascript
深入理解javascript变量声明
Nov 20 Javascript
javascript另类方法实现htmlencode()与htmldecode()函数实例分析
Nov 17 Javascript
Vue中组件之间数据的传递的示例代码
Sep 08 Javascript
jQuery实现对网页节点的增删改查功能示例
Sep 18 jQuery
通过vue提供的keep-alive减少对服务器的请求次数
Apr 01 Javascript
如何安装控制器JavaScript生成插件详解
Oct 21 Javascript
socket在egg中的使用实例代码详解
May 30 Javascript
layui下拉框获取下拉值(select)的例子
Sep 10 Javascript
vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法详解
Oct 15 Javascript
动态的改变IFrame的高度实现IFrame自动伸展适应高度
Dec 28 #Javascript
2012年开发人员的16款新鲜的jquery插件体验分享
Dec 28 #Javascript
web性能优化之javascript性能调优
Dec 28 #Javascript
javascript的字符串按引用复制和传递,按值来比较介绍与应用
Dec 28 #Javascript
javascript 利用Image对象实现的埋点(某处的点击数)统计
Dec 28 #Javascript
Javascript 加载和执行-性能提高篇
Dec 28 #Javascript
javascript延时加载之defer测试
Dec 28 #Javascript
You might like
无线电广播的开始
2002/01/30 无线电
如何正确配置Nginx + PHP
2016/07/15 PHP
php使用curl代理实现抓取数据的方法
2017/02/03 PHP
Yii2 中实现单点登录的方法
2018/03/09 PHP
快速保存网页中所有图片的方法
2006/06/23 Javascript
兼容FireFox 的 js 日历 支持时间的获取
2009/03/04 Javascript
js更优雅的兼容
2010/08/12 Javascript
jQuery获得IE版本不准确webbrowser的解决方法
2014/02/23 Javascript
常用jQuery选择器总结
2014/07/11 Javascript
javascript面向对象之共享成员属性与方法及prototype关键字用法
2015/01/13 Javascript
JavaScript随机生成信用卡卡号的方法
2015/04/07 Javascript
javascript同步服务器时间和同步倒计时小技巧
2015/09/24 Javascript
JavaScript递归操作实例浅析
2016/10/31 Javascript
javascript history对象详解
2017/02/09 Javascript
JavaScript中创建对象的7种模式详解
2017/02/21 Javascript
JS实现电商放大镜效果
2017/08/24 Javascript
浅谈webpack打包之后的文件过大的解决方法
2018/03/07 Javascript
vue中的适配px2rem示例代码
2018/11/19 Javascript
JavaScript箭头函数中的this详解
2019/06/19 Javascript
JavaScript用document.write()输出换行的示例代码
2020/11/26 Javascript
Python算法之栈(stack)的实现
2014/08/18 Python
python比较2个xml内容的方法
2015/05/11 Python
Python文件右键找不到IDLE打开项解决办法
2015/06/08 Python
python实现比较文件内容异同
2018/06/22 Python
Python使用folium excel绘制point
2019/01/03 Python
Python基础之循环语句用法示例【for、while循环】
2019/03/23 Python
python保留格式汇总各部门excel内容的实现思路
2020/06/01 Python
Python+logging输出到屏幕将log日志写入文件
2020/11/11 Python
意大利灯具购物网站:Lampade.it
2018/10/18 全球购物
小学教师的个人自我鉴定
2013/10/26 职场文书
《小松树和大松树》教学反思
2014/02/20 职场文书
校长竞聘演讲稿
2014/05/16 职场文书
《海上日出》教学反思
2016/02/23 职场文书
坚持不是死撑,更重要的是心态
2019/08/19 职场文书
Mac电脑OS系统下安装Nginx的详细教程
2022/04/14 Servers
Python sklearn分类决策树方法详解
2022/09/23 Python