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 相关文章推荐
写出更好的JavaScript程序之undefined篇(中)
Nov 23 Javascript
ExtJS自定义主题(theme)样式详解
Nov 18 Javascript
如何在JavaScript中实现私有属性的写类方式(二)
Dec 04 Javascript
JQuery实现动态适时改变字体颜色的方法
Mar 10 Javascript
微信小程序自定义select下拉选项框组件的实现代码
Aug 28 Javascript
Vue-Cli 3.0 中配置高德地图的两种方式
Jun 19 Javascript
vue实现日历备忘录功能
Sep 24 Javascript
微信小程序之下拉列表实现方法解析(附完整源码)
Aug 23 Javascript
JS实现拼图游戏
Jan 29 Javascript
jquery选择器和属性对象的操作实例分析
Jan 10 jQuery
十分钟教你上手ES2020新特性
Feb 12 Javascript
解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题
Sep 02 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 is_dir() 判断给定文件名是否是一个目录
2010/05/10 PHP
php递归方法实现无限分类实例代码
2014/02/28 PHP
php操纵mysqli数据库的实现方法
2016/09/18 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
JavaScript类型转换方法及需要注意的问题小结(挺全面)
2010/11/11 Javascript
form表单action提交的js部分与html部分
2014/01/07 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
浅析javascript中function 的 length 属性
2014/05/27 Javascript
Js遍历键值对形式对象或Map形式的方法
2016/08/08 Javascript
JS 终止执行的实现方法
2016/11/24 Javascript
Bootstrap Modal对话框如何在关闭时触发事件
2016/12/02 Javascript
jQuery UI Grid 模态框中的表格实例代码
2017/04/01 jQuery
使用重写url机制实现验证码换一张功能
2017/08/01 Javascript
简单实现jquery隔行变色
2017/11/09 jQuery
AngularJs点击状态值改变背景色的实例
2017/12/18 Javascript
vue如何进行动画的封装
2018/09/26 Javascript
nodejs中函数的调用实例详解
2018/10/31 NodeJs
JS前端知识点总结之内置对象,日期对象和定时器相关操作
2019/07/05 Javascript
Vue发布项目实例讲解
2019/07/17 Javascript
Vue看了就会的8个小技巧
2021/01/21 Vue.js
[02:41]DOTA2英雄基础教程 谜团
2013/12/10 DOTA
[51:53]完美世界DOTA2联赛循环赛 LBZS vs DM BO2第二场 11.01
2020/11/02 DOTA
python实现监控linux性能及进程消耗性能的方法
2014/07/25 Python
python根据京东商品url获取产品价格
2015/08/09 Python
python3中int(整型)的使用教程
2017/03/23 Python
python实现随机梯度下降(SGD)
2020/03/24 Python
JS设计模式之责任链模式实例详解
2018/02/03 Python
OpenCV图像颜色反转算法详解
2019/05/13 Python
Python获取好友地区分布及好友性别分布情况代码详解
2019/07/10 Python
Python 使用threading+Queue实现线程池示例
2019/12/21 Python
美体小铺瑞典官方网站:The Body Shop瑞典
2018/01/27 全球购物
电子信息科学专业自荐信
2014/01/30 职场文书
经理助理岗位职责
2015/02/02 职场文书
士兵突击观后感
2015/06/16 职场文书
大学生支教感言
2015/08/01 职场文书
Python自动化工具之实现Excel转Markdown表格
2022/04/08 Python