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 相关文章推荐
IE DOM实现存在的部分问题及解决方法
Jul 25 Javascript
jquery下利用jsonp跨域访问实现方法
Jul 29 Javascript
input按钮的事件处理大全
Dec 10 Javascript
JavaScript 继承使用分析
May 12 Javascript
jquery内置验证(validate)使用方法示例(表单验证)
Dec 04 Javascript
用html+css+js实现的一个简单的图片切换特效
May 28 Javascript
JS模拟实现Select效果代码
Sep 24 Javascript
学习javascript面向对象 掌握创建对象的9种方式
Jan 04 Javascript
JavaScript中匿名函数的用法及优缺点详解
Jun 01 Javascript
JS实现浏览器打印、打印预览示例
Feb 28 Javascript
AngularJS 验证码60秒倒计时功能的实现
Jun 05 Javascript
Vue.extend 登录注册模态框的实现
Dec 29 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下安装配置fckeditor编辑器的方法
2011/03/02 PHP
php中cookie的使用方法
2014/03/29 PHP
PHP如何通过AJAX方式实现登录功能
2015/11/23 PHP
Linux基于php-fpm模式的lamp搭建phpmyadmin的方法
2018/10/25 PHP
PHP getID3类的使用方法学习笔记【附getID3源码下载】
2019/10/18 PHP
DOM2非标准但却支持很好的几个属性小结
2012/01/21 Javascript
使用PHP+JQuery+Ajax分页的实现
2013/04/23 Javascript
js将当前时间格式转换成时间搓(自写)
2013/09/26 Javascript
javascript不可用的问题探究
2013/10/01 Javascript
jQuery中操控hidden、disable等无值属性的方法
2014/01/06 Javascript
jQuery中innerHeight()方法用法实例
2015/01/19 Javascript
JavaScript中用getDate()方法返回指定日期的教程
2015/06/09 Javascript
Javascript中判断对象是否为空
2015/06/10 Javascript
Javascript实现网络监测的方法
2015/07/31 Javascript
js实现文本框宽度自适应文本宽度的方法
2015/08/13 Javascript
jQuery实现分章节锚点“回到顶部”动画特效代码
2015/10/23 Javascript
angularjs创建弹出框实现拖动效果
2020/08/25 Javascript
jQuery解析返回的xml和json方法详解
2017/01/05 Javascript
关于jquery form表单序列化的注意事项详解
2017/08/01 jQuery
原生js实现日历效果
2020/03/02 Javascript
pycharm 使用心得(二)设置字体大小
2014/06/05 Python
轻量级的Web框架Flask 中模块化应用的实现
2017/09/11 Python
python模块之time模块(实例讲解)
2017/09/13 Python
Django框架教程之中间件MiddleWare浅析
2019/12/29 Python
python GUI库图形界面开发之PyQt5简单绘图板实例与代码分析
2020/03/08 Python
python中判断数字是否为质数的实例讲解
2020/12/06 Python
css3实现一个div设置多张背景图片及background-image属性实例演示
2017/08/10 HTML / CSS
美国的Eastbay旗下的运动款子品牌:Final-Score
2018/01/01 全球购物
写一个函数,要求输入一个字符串和一个字符长度,对该字符串进行分隔
2015/07/30 面试题
土建资料员岗位职责
2014/01/04 职场文书
商场父亲节活动方案
2014/08/27 职场文书
勇敢的心观后感
2015/06/09 职场文书
钢铁是怎样炼成的读书笔记
2015/06/29 职场文书
多人股份制合作协议书
2016/03/19 职场文书
新手入门Jvm-- JVM对象创建与内存分配机制
2021/06/18 Java/Android
Pycharm连接远程服务器并远程调试的全过程
2021/06/24 Python