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 相关文章推荐
jQuery + Flex 通过拖拽方式动态改变图片的代码
Aug 03 Javascript
javascript 闭包
Sep 15 Javascript
js中更短的 Array 类型转换
Oct 30 Javascript
javascript时间自动刷新实现原理与步骤
Jan 06 Javascript
js 图片随机不定向浮动的实现代码
Jul 02 Javascript
js浮动图片的动态效果
Jul 10 Javascript
Js nodeType 属性全面解析
Nov 14 Javascript
JavaScript实现翻页功能(附效果图)
Feb 16 Javascript
JS常见创建类的方法小结【工厂方式,构造器方式,原型方式,联合方式等】
Apr 01 Javascript
浅谈vue自定义全局组件并通过全局方法 Vue.use() 使用该组件
Dec 07 Javascript
加快Vue项目的开发速度的方法
Dec 12 Javascript
测量JavaScript函数的性能各种方式对比
Apr 27 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
发款php蜘蛛统计插件只要有mysql就可用
2010/10/12 PHP
解析php多线程下载远程多个文件
2013/06/25 PHP
微信公众平台开发之天气预报功能
2015/08/31 PHP
PHP实现的AES加密、解密封装类与用法示例
2018/08/02 PHP
PHP实现的权重算法示例【可用于游戏根据权限来随机物品】
2019/02/15 PHP
JavaScript 不只是脚本
2007/05/30 Javascript
js chrome浏览器判断代码
2010/03/28 Javascript
js动态添加onload、onresize、onscroll事件(另类方法)
2012/12/26 Javascript
jQuery对象和Javascript对象之间转换的实例代码
2013/03/20 Javascript
JS+CSS实现简单滑动门(滑动菜单)效果
2015/09/19 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
2016/07/20 Javascript
JS禁止查看网页源代码的实现方法
2016/10/12 Javascript
JavaScript实现form表单的多文件上传
2020/03/27 Javascript
Vue.js手风琴菜单组件开发实例
2017/05/16 Javascript
详解利用 Vue.js 实现前后端分离的RBAC角色权限管理
2017/09/15 Javascript
Vue.js如何使用Socket.IO的示例代码
2019/09/05 Javascript
token 机制和实现方式
2020/12/15 Javascript
详解Python当中的字符串和编码
2015/04/25 Python
Python使用cx_Oracle调用Oracle存储过程的方法示例
2017/10/07 Python
Python装饰器原理与简单用法实例分析
2018/04/29 Python
解决PyCharm不运行脚本,而是运行单元测试的问题
2019/01/17 Python
Python直接赋值、浅拷贝与深度拷贝实例分析
2019/06/18 Python
django rest framework 实现用户登录认证详解
2019/07/29 Python
OpenCV模板匹配matchTemplate的实现
2019/10/18 Python
python matplotlib 绘图 和 dpi对应关系详解
2020/03/14 Python
Python打印特殊符号及对应编码解析
2020/05/07 Python
Python中内建模块collections如何使用
2020/05/27 Python
Python Selenium库的基本使用教程
2021/01/04 Python
Mixbook加拿大:照片书,照片卡,剪贴簿,年历和日历
2017/02/21 全球购物
Supersmart英国:欧洲市场首批食品补充剂供应商之一
2018/05/05 全球购物
比利时的在线灯具店:Lampen24.be
2019/07/01 全球购物
物业管理员岗位职责范文
2013/11/25 职场文书
巾帼标兵事迹材料
2014/12/26 职场文书
爱心捐款感谢信
2015/01/20 职场文书
2015年精神文明建设工作总结
2015/04/21 职场文书
MySQL 存储过程的优缺点分析
2021/05/20 MySQL