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 eval解析JSON中的注意点介绍
Aug 23 Javascript
深入理解jQuery中live与bind方法的区别
Dec 18 Javascript
JS日期加减,日期运算代码
Nov 05 Javascript
Javascript实现单例模式
Jan 24 Javascript
JS 拦截全局ajax请求实例解析
Nov 29 Javascript
JS返回只包含数字类型的数组实例分析
Dec 16 Javascript
vue.js单页面应用实例的简单实现
Apr 10 Javascript
利用require.js与angular搭建spa应用的方法实例
Jul 19 Javascript
使用JavaScript实现点击循环切换图片效果
Sep 03 Javascript
JavaScript基础心法 数据类型
Mar 05 Javascript
解决layui的使用以及针对select、radio等表单组件不显示的问题
Sep 05 Javascript
小程序实现上下切换位置
Nov 16 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实现递归复制整个文件夹的类实例
2015/08/03 PHP
设定php简写功能的方法
2019/11/28 PHP
IE bug table元素的innerHTML
2010/01/11 Javascript
js常用代码段整理
2011/11/30 Javascript
体验js中splice()的强大(插入、删除或替换数组的元素)
2013/01/16 Javascript
js下拉框二级关联菜单效果代码具体实现
2013/08/03 Javascript
js中arguments的用法(实例讲解)
2013/11/30 Javascript
鼠标拖拽移动子窗体的JS实现
2014/02/25 Javascript
js实现绿白相间竖向网页百叶窗动画切换效果
2015/03/02 Javascript
javascript顺序加载图片的方法
2015/07/18 Javascript
javascript中eval和with用法实例总结
2015/11/30 Javascript
如何快速解决JS或Jquery ajax异步跨域的问题
2018/01/08 jQuery
js实现左右两侧浮动广告
2018/07/09 Javascript
JavaScript简单实现关键字文本搜索高亮显示功能示例
2018/07/25 Javascript
原生JS使用Canvas实现拖拽式绘图功能
2019/06/05 Javascript
新手如何快速理解js异步编程
2019/06/24 Javascript
Layui Table js 模拟选中checkbox的例子
2019/09/03 Javascript
Layer+Echarts构建弹出层折线图的方法
2019/09/25 Javascript
Python 元类使用说明
2009/12/18 Python
python输入错误密码用户锁定实现方法
2017/11/27 Python
Python排序搜索基本算法之归并排序实例分析
2017/12/08 Python
python实现冒泡排序算法的两种方法
2018/03/10 Python
Python3中的列表生成式、生成器与迭代器实例详解
2018/06/11 Python
Python中and和or如何使用
2020/05/28 Python
解决pytorch 模型复制的一些问题
2021/03/03 Python
CSS3 选择器 属性选择器介绍
2012/01/21 HTML / CSS
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
The Hut英国:英国领先的豪华在线百货商店
2019/07/26 全球购物
英国领先的游戏零售商:GAME
2019/09/24 全球购物
高级护理专业毕业生推荐信
2013/12/25 职场文书
幼儿园教师备课制度
2014/01/12 职场文书
庆中秋节主题活动方案
2014/02/03 职场文书
公司开业庆典策划方案
2014/06/04 职场文书
2019销售早会主持词
2019/06/27 职场文书
Vue h函数的使用详解
2022/02/18 Vue.js
分析SQL窗口函数之聚合窗口函数
2022/04/21 Oracle