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 剧场版 你必须知道的javascript
May 27 Javascript
Js日期选择自动填充到输入框(界面漂亮兼容火狐)
Aug 02 Javascript
JS复制到剪贴板示例代码
Oct 30 Javascript
让alert不出现弹窗的两种方法
May 18 Javascript
JQuery表格拖动调整列宽效果(自己动手写的)
Sep 01 Javascript
原生js制作日历控件实例分享
Apr 06 Javascript
对Js OOP编程 创建对象的一些全面理解
Jul 26 Javascript
详谈js中数组(array)和对象(object)的区别
Feb 27 Javascript
在小程序中使用Echart图表的示例代码
Aug 02 Javascript
Vue Prop属性功能与用法实例详解
Feb 23 Javascript
vue-cli项目使用mock数据的方法(借助express)
Apr 15 Javascript
JavaScript数组排序功能简单实现
May 14 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中的多态性[译]
2011/08/02 PHP
laravel5.6 框架操作数据 Eloquent ORM用法示例
2020/01/26 PHP
JQuery+DIV自定义滚动条样式的具体实现
2013/06/25 Javascript
JS实现超精简的链接列表在固定区域内滚动效果代码
2015/11/04 Javascript
JS提交form表单实例分析
2015/12/10 Javascript
基于javascript html5实现3D翻书特效
2016/03/14 Javascript
老生常谈js动态添加事件--- 事件委托
2016/07/19 Javascript
Vue.js每天必学之指令系统与自定义指令
2016/09/07 Javascript
js 点击a标签 获取a的自定义属性方法
2016/11/21 Javascript
js简单正则验证汉字英文及下划线的方法
2016/11/28 Javascript
浅谈JavaScript的闭包函数
2016/12/08 Javascript
JS实现搜索框文字可删除功能
2016/12/28 Javascript
JS生成一维码(条形码)功能示例
2017/01/19 Javascript
详解vue的数据binding绑定原理
2017/04/12 Javascript
Vue实现商品飞入购物车效果(电商项目)
2019/11/26 Javascript
vue 实现一个简单的全局调用弹窗案例
2020/09/10 Javascript
[01:56]《DOTA2》中文配音CG
2013/04/22 DOTA
Python 过滤字符串的技巧,map与itertools.imap
2008/09/06 Python
python中实现php的var_dump函数功能
2015/01/21 Python
python将字符串转换成json的方法小结
2019/07/09 Python
Python下opencv图像阈值处理的使用笔记
2019/08/04 Python
wxPython+Matplotlib绘制折线图表
2019/11/19 Python
python DES加密与解密及hex输出和bs64格式输出的实现代码
2020/04/13 Python
python实现文法左递归的消除方法
2020/05/22 Python
python3 循环读取excel文件并写入json操作
2020/07/14 Python
python pillow库的基础使用教程
2021/01/13 Python
HTML5 的新的表单元素(datalist/keygen/output)使用介绍
2013/07/19 HTML / CSS
Nike瑞典官方网站:Nike.com (SE)
2018/11/26 全球购物
乔迁宴答谢词
2014/01/21 职场文书
诚信承诺书模板
2014/05/26 职场文书
幼儿园安全责任书范本
2014/07/24 职场文书
群众路线教育实践活动个人对照检查材料思想汇报(社区班子)
2014/10/06 职场文书
vue3中provide && inject的使用
2021/07/01 Vue.js
Go 语言中 20 个占位符的整理
2021/10/16 Golang
详解MySql中InnoDB存储引擎中的各种锁
2022/02/12 MySQL
MySQL如何快速创建800w条测试数据表
2022/03/17 MySQL