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的消息提示插件之旅 DivAlert(三)
Apr 01 Javascript
JQuery与JSon实现的无刷新分页代码
Sep 13 Javascript
js 删除数组的几种方法小结
Feb 21 Javascript
JQuery中上下文选择器实现方法
May 18 Javascript
AngularJS实现元素显示和隐藏的几个案例
Dec 09 Javascript
React Native第三方平台分享的实例(Android,IOS双平台)
Aug 04 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
Aug 25 Javascript
Angular实现的简单查询天气预报功能示例
Dec 27 Javascript
WebSocket的通信过程与实现方法详解
Apr 29 Javascript
详解vuex之store源码简单解析
Jun 13 Javascript
javascript用defineProperty实现简单的双向绑定方法
Apr 03 Javascript
vue二维数组循环嵌套方式 循环数组、循环嵌套数组
Apr 24 Vue.js
动态的改变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+xslt在windows平台上
2006/10/09 PHP
使用ThinkPHP自带的Http类下载远程图片到本地的实现代码
2011/08/02 PHP
PHP提示Notice: Undefined variable的解决办法
2012/11/24 PHP
使用php测试硬盘写入速度示例
2014/01/27 PHP
php提交表单发送邮件的方法
2015/03/20 PHP
在Linux系统的服务器上隐藏PHP版本号的方法
2015/06/06 PHP
PHP设计模式之组合模式定义与应用示例
2020/02/01 PHP
JS实现打开本地文件或文件夹
2021/03/09 Javascript
基于jquery实现状态限定编辑的代码
2012/02/11 Javascript
jquery实现简单的拖拽效果实例兼容所有主流浏览器(优化篇)
2013/06/28 Javascript
在服务端(Page.Write)调用自定义的JS方法详解
2013/08/09 Javascript
jQuery.Highcharts.js绘制柱状图饼状图曲线图
2015/03/14 Javascript
JS判断网页广告是否被浏览器拦截过滤的代码
2015/04/05 Javascript
在JavaScript中模拟类(class)及类的继承关系
2016/05/20 Javascript
AngularJS Bootstrap详细介绍及实例代码
2016/07/28 Javascript
Angular2学习笔记——详解路由器模型(Router)
2016/12/02 Javascript
jquery与js实现全选功能的区别
2017/06/11 jQuery
MVVM框架下实现分页功能示例
2018/06/14 Javascript
Vue.js 中 axios 跨域访问错误问题及解决方法
2018/11/21 Javascript
Vue实现push数组并删除的例子
2019/11/01 Javascript
Python实现时钟显示效果思路详解
2018/04/11 Python
详解Python用户登录接口的方法
2019/04/17 Python
Python多线程:主线程等待所有子线程结束代码
2020/04/25 Python
Python导入数值型Excel数据并生成矩阵操作
2020/06/09 Python
python tqdm库的使用
2020/11/30 Python
CSS3 box-sizing属性
2009/04/17 HTML / CSS
CSS3毛玻璃效果(blur)有白边问题的解决方法
2016/11/15 HTML / CSS
boostrap modal 闪现问题的解决方法
2020/09/01 HTML / CSS
美国杂志订阅折扣与优惠网站:Magazines.com
2016/08/31 全球购物
全球知名提供各类营养保健品的零售商:Vitamin Shoppe
2016/10/09 全球购物
沙特阿拉伯电子产品和家用电器购物网站:Black Box
2019/07/24 全球购物
药学专业个人的自我评价
2013/12/31 职场文书
五一家具促销方案
2014/01/10 职场文书
思想作风建设心得体会
2014/10/22 职场文书
MySQL kill不掉线程的原因
2021/05/07 MySQL
MySQL里面的子查询的基本使用
2021/08/02 MySQL