JavaScript var声明变量背后的原理示例解析


Posted in Javascript onOctober 12, 2013

只要是写过点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里的each使用方法详解
Dec 22 Javascript
关于javascript function对象那些迷惑分析
Oct 24 Javascript
Javascript查询DBpedia小应用实例学习
Mar 07 Javascript
ajaxFileUpload.js插件支持多文件上传的方法
Sep 02 Javascript
用JavaScript显示浏览器客户端信息的超相近教程
Jun 18 Javascript
JavaScript基于ajax编辑信息用法实例
Jul 15 Javascript
jquery带翻页动画的电子杂志代码分享
Aug 21 Javascript
jQuery+css实现的蓝色水平二级导航菜单效果代码
Sep 11 Javascript
浅谈JavaScript中的属性:如何遍历属性
Sep 14 Javascript
基于百度地图api清除指定覆盖物(Overlay)的方法
Jan 26 Javascript
解决淘宝cnpm 安装后cnpm不是内部或外部命令的问题
May 17 Javascript
Vue项目打包编译优化方案
Sep 16 Javascript
原生js操作checkbox用document.getElementById实现
Oct 12 #Javascript
基于jquery的9行js轻松实现tab控件示例
Oct 12 #Javascript
JavaScript对象学习经验整理
Oct 12 #Javascript
js修改input的type属性问题探讨
Oct 12 #Javascript
5秒后跳转到另一个页面的js代码
Oct 12 #Javascript
设置checkbox为只读(readOnly)的两种方式
Oct 11 #Javascript
extjs表格文本启用选择复制功能具体实现
Oct 11 #Javascript
You might like
PHP SOCKET编程详解
2015/05/22 PHP
PHP实现PDO操作mysql存储过程示例
2019/02/13 PHP
学习YUI.Ext 第二天
2007/03/10 Javascript
基于jQuery UI CSS Framework开发Widget的经验
2010/08/21 Javascript
JSON+JavaScript处理JSON的简单例子
2013/03/20 Javascript
jquery 显示*天*时*分*秒实现时间计时器
2014/05/07 Javascript
基于NodeJS的前后端分离的思考与实践(三)轻量级的接口配置建模框架
2014/09/26 NodeJs
jQuery操作cookie方法实例教程
2014/11/25 Javascript
jQuery手机浏览器中拖拽动作的艰难性分析
2015/02/04 Javascript
jQuery实现菜单感应鼠标滑动动画效果的方法
2015/02/28 Javascript
微信小程序 保留小数(toFixed)详细介绍
2016/11/16 Javascript
JavaScript实现公历转农历功能示例
2017/02/13 Javascript
详解vue2 $watch要注意的问题
2017/09/08 Javascript
Vue 项目中遇到的跨域问题及解决方法(后台php)
2018/03/28 Javascript
vue mounted 调用两次的完美解决办法
2018/10/29 Javascript
JS根据Unix时间戳显示发布时间是多久前【项目实测】
2019/07/10 Javascript
Vue解析带html标签的字符串为dom的实例
2019/11/13 Javascript
解决vue项目 build之后资源文件找不到的问题
2020/09/12 Javascript
详解VUE中的插值( Interpolation)语法
2020/10/18 Javascript
pandas的object对象转时间对象的方法
2018/04/11 Python
使用Python编写Prometheus监控的方法
2018/10/15 Python
python_opencv用线段画封闭矩形的实例
2018/12/05 Python
python基础梳理(一)(推荐)
2019/04/06 Python
python爬虫之快速对js内容进行破解
2019/07/09 Python
Python Opencv中用compareHist函数进行直方图比较对比图片
2020/04/07 Python
Python实现简单的2048小游戏
2021/03/01 Python
世界上最好的足球商店:Unisport
2019/03/02 全球购物
电子信息专业自荐书
2014/02/04 职场文书
母亲节感恩活动记录
2014/03/16 职场文书
纪念九一八爱国演讲稿600字
2014/09/14 职场文书
群众路线自查自纠工作情况报告
2014/10/28 职场文书
客户答谢会致辞
2015/01/20 职场文书
交通安全教育主题班会
2015/08/12 职场文书
PHP实现两种排课方式
2021/06/26 PHP
Go语言基础切片的创建及初始化示例详解
2021/11/17 Golang
世界无敌的ICOM IC-R9500宽频接收机
2022/03/25 无线电