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 相关文章推荐
js限制文本框为整数和货币的函数代码
Oct 13 Javascript
Jquery easyui 下loaing效果示例代码
Aug 12 Javascript
jQuery实现响应浏览器缩放大小并改变背景颜色
Oct 31 Javascript
javascript实现抽奖程序的简单实例
Jun 07 Javascript
WebSocket+node.js创建即时通信的Web聊天服务器
Aug 08 Javascript
js实现前端分页页码管理
Jan 06 Javascript
完美解决spring websocket自动断开连接再创建引发的问题
Mar 02 Javascript
对layui中表单元素的使用详解
Aug 15 Javascript
微信小程序渲染性能调优小结
Jul 30 Javascript
jQuery实现倒计时功能完整示例
Jun 01 jQuery
JS如何生成动态列表
Sep 22 Javascript
vue项目如何打包之项目打包优化(让打包的js文件变小)
Apr 30 Vue.js
原生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
PHP4与PHP3中一个不兼容问题的解决方法
2006/10/09 PHP
PHP Session_Regenerate_ID函数双释放内存破坏漏洞
2011/01/27 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
ThinkPHP5 验证器的具体使用
2018/05/31 PHP
jQuery Ajax 全解析
2009/02/08 Javascript
ie下动态加态js文件的方法
2011/09/13 Javascript
JS构建页面的DOM节点结构的实现代码
2011/12/09 Javascript
JS中引用百度地图并将百度地图的logo和信息去掉
2013/09/29 Javascript
通过action传过来的值在option获取进行验证的方法
2013/11/14 Javascript
js使用心得分享
2015/01/13 Javascript
jquery滚动加载数据的方法
2015/03/09 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
2017/06/19 Javascript
jquery操作ul的一些操作笔记整理(干货)
2017/08/31 jQuery
three.js中文文档学习之通过模块导入
2017/11/20 Javascript
关于Vue单页面骨架屏实践记录
2017/12/13 Javascript
基于vue开发的在线付费课程应用过程
2018/01/25 Javascript
一种angular的方法级的缓存注解(装饰器)
2018/03/13 Javascript
JavaScript设计模式之工厂模式和抽象工厂模式定义与用法分析
2018/07/26 Javascript
vue-cli安装使用流程步骤详解
2018/11/08 Javascript
详解vue中this.$emit()的返回值是什么
2019/04/07 Javascript
js实现录音上传功能
2019/11/22 Javascript
jquery更改元素属性attr()方法操作示例
2020/05/22 jQuery
webstorm建立vue-cli脚手架的傻瓜式教程
2020/09/22 Javascript
[38:32]完美世界DOTA2联赛循环赛 Forest vs DM 第二场 11.06
2020/11/06 DOTA
Python实现读取目录所有文件的文件名并保存到txt文件代码
2014/11/22 Python
深入理解Python中装饰器的用法
2016/06/28 Python
python GUI库图形界面开发之PyQt5信号与槽多窗口数据传递详细使用方法与实例
2020/03/08 Python
Django使用rest_framework写出API
2020/05/21 Python
python 用opencv实现图像修复和图像金字塔
2020/11/27 Python
澳大利亚在线批发商:Simply Wholesale
2021/02/24 全球购物
Java里面StringBuilder和StringBuffer有什么区别
2016/06/06 面试题
销售代表求职自荐信
2013/10/01 职场文书
师范大学音乐表演专业求职信
2013/10/23 职场文书
《北大荒的秋天》教学反思
2014/04/14 职场文书
淘宝客服专员岗位职责
2015/04/07 职场文书
运动会3000米加油稿
2015/07/21 职场文书