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判断IE6/IE7/FF的代码[XMLHttpRequest]
Feb 16 Javascript
jquery列表拖动排列(由项目提取相当好用)
Jun 17 Javascript
jquery实现鼠标滑过后动态图片提示效果实例
Aug 10 Javascript
jquery+CSS实现的多级竖向展开树形TRee菜单效果
Aug 24 Javascript
js实现登录与注册界面
Nov 01 Javascript
vue2.0 element-ui中el-select选择器无法显示选中的内容(解决方法)
Aug 24 Javascript
Angular resolve基础用法详解
Oct 03 Javascript
微信小程序实现用table显示数据库反馈的多条数据功能示例
May 07 Javascript
javascript写一个ajax自动拦截并下载数据代码实例
Sep 07 Javascript
小程序实现背景音乐播放和暂停
Jun 19 Javascript
VUE前端从后台请求过来的数据进行转换数据结构操作
Nov 11 Javascript
vue实现防抖的实例代码
Jan 11 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
在PHP3中实现SESSION的功能(三)
2006/10/09 PHP
PHP中的socket_read和socket_recv区别详解
2015/02/09 PHP
PHP异常类及异常处理操作实例详解
2018/12/19 PHP
PHP的微信支付接口使用方法讲解
2019/03/08 PHP
js 刷新页面的代码小结 推荐
2010/04/02 Javascript
textarea中的手动换行处理的jquery代码
2011/02/26 Javascript
select标签模拟/美化方法采用JS外挂式插件
2013/04/01 Javascript
JavaScript自学笔记(必看篇)
2016/06/23 Javascript
JQuery 获取Dom元素的实例讲解
2017/07/08 jQuery
React 使用recharts实现散点地图的示例代码
2018/12/07 Javascript
TypeScript开发Node.js程序的方法
2019/04/30 Javascript
探索JavaScript中私有成员的相关知识
2019/06/13 Javascript
vue element upload组件 file-list的动态绑定实现
2019/10/11 Javascript
采用python实现简单QQ单用户机器人的方法
2014/07/03 Python
Django实现组合搜索的方法示例
2018/01/23 Python
python多线程调用exit无法退出的解决方法
2019/02/18 Python
python之pymysql模块简单应用示例代码
2019/12/16 Python
Python3.x+迅雷x 自动下载高分电影的实现方法
2020/01/12 Python
python自动下载图片的方法示例
2020/03/25 Python
jupyter notebook运行命令显示[*](解决办法)
2020/05/18 Python
让Django的BooleanField支持字符串形式的输入方式
2020/05/20 Python
linux系统下pip升级报错的解决方法
2021/01/31 Python
HTML5里的placeholder属性使用实例和美化显示效果的方法
2014/04/23 HTML / CSS
印尼最大的婴儿用品购物网站:Orami
2017/09/28 全球购物
印尼网上商店:Alfacart.com
2019/03/11 全球购物
Madewell澳大利亚官方网站:美国休闲服饰品牌
2019/07/18 全球购物
泰国排名第一的家居用品中心:HomePro
2020/11/18 全球购物
外企C语言笔试题
2013/11/10 面试题
机电专业个人自荐信格式模板
2013/09/23 职场文书
广告学专业推荐信范文
2013/11/23 职场文书
幼儿教师考核制度
2014/01/25 职场文书
趣味体育活动方案
2014/02/08 职场文书
捐款活动总结
2014/08/27 职场文书
师德师风自查总结
2014/10/14 职场文书
Windows server 2012 R2 安装IIS服务器
2022/04/29 Servers
Java 多线程并发FutureTask
2022/06/28 Java/Android