深入解析JavaScript中的变量作用域


Posted in Javascript onDecember 06, 2013

在学习JavaScript的变量作用域之前,我们应当明确几点:

•JavaScript的变量作用域是基于其特有的作用域链的。

•JavaScript没有块级作用域。

•函数中声明的变量在整个函数中都有定义。

1、JavaScript的作用域链
首先看下下面这段代码:

<script type="text/javascript"> var rain = 1; function rainman(){ var man = 2; function inner(){ var innerVar = 4; alert(rain); } inner(); //调用inner函数 } rainman(); //调用rainman函数</script>

观察alert(rain);这句代码。JavaScript首先在inner函数中查找是否定义了变量rain,如果定义了则使用inner函数中的rain变量;如果inner函数中没有定义rain变量,JavaScript则会继续在rainman函数中查找是否定义了rain变量,在这段代码中rainman函数体内没有定义rain变量,则JavaScript引擎会继续向上(全局对象)查找是否定义了rain;在全局对象中我们定义了rain = 1,因此最终结果会弹出'1'。

作用域链:JavaScript需要查询一个变量x时,首先会查找作用域链的第一个对象,如果以第一个对象没有定义x变量,JavaScript会继续查找有没有定义x变量,如果第二个对象没有定义则会继续查找,以此类推。

上面的代码涉及到了三个作用域链对象,依次是:inner、rainman、window。

2、函数体内部,局部变量的优先级比同名的全局变量高。

<script type="text/javascript"> var rain = 1; //定义全局变量 rain function check(){ var rain = 100; //定义局部变量rain alert( rain ); //这里会弹出 100 } check(); alert( rain ); //这里会弹出1</script>

3、JavaScript没有块级作用域。

这一点也是JavaScript相比其它语言较灵活的部分。

仔细观察下面的代码,你会发现变量i、j、k作用域是相同的,他们在整个rain函数体内都是全局的。

<script type="text/javascript"> function rainman(){ // rainman函数体内存在三个局部变量 i j k var i = 0; if ( 1 ) { var j = 0; for(var k = 0; k < 3; k++) { alert( k ); //分别弹出 0 1 2 } alert( k ); //弹出3 } alert( j ); //弹出0 }</script>

4、函数中声明的变量在整个函数中都有定义。

首先观察这段代码:

<script type="text/javascript"> function rain(){ var x = 1; function man(){ x = 100; } man(); //调用man alert( x ); //这里会弹出 100 } rain(); //调用rain</script>

上面得代码说明了,变量x在整个rain函数体内都可以使用,并可以重新赋值。由于这条规则,会产生“匪夷所思”的结果,观察下面的代码。
<script type="text/javascript"> var x = 1; function rain(){ alert( x ); //弹出 'undefined',而不是1 var x = 'rain-man'; alert( x ); //弹出 'rain-man' } rain();</script>

是由于在函数rain内局部变量x在整个函数体内都有定义( var x= 'rain-man',进行了声明),所以在整个rain函数体内隐藏了同名的全局变量x。这里之所以会弹出'undefined'是因为,第一个执行alert(x)时,局部变量x仍未被初始化。

所以上面的rain函数等同于下面的函数:

function rain(){ var x; alert( x ); x = 'rain-man'; alert( x );}

5、未使用var关键字定义的变量都是全局变量。
<script type="text/javascript"> function rain(){ x = 100; //声明了全局变量x并进行赋值 } rain(); alert( x ); //会弹出100 </script>

这也是JavaScript新手常见的错误,无意之中留下的许多全局变量。

6、全局变量都是window对象的属性

<script type="text/javascript"> var x = 100 ; alert( window.x );//弹出100 alert(x);</script>

等同于下面的代码
<script type="text/javascript"> window.x = 100; alert( window.x ); alert(x)</script>
Javascript 相关文章推荐
jquery中通过父级查找进行定位示例
Jun 28 Javascript
告诉你什么是javascript的回调函数
Sep 04 Javascript
jQuery中first()方法用法实例
Jan 06 Javascript
JS代码随机生成姓名、手机号、身份证号、银行卡号
Apr 27 Javascript
JavaScript学习笔记--常用的互动方法
Dec 07 Javascript
JS实现发送短信验证后按钮倒计时功能(防止刷新倒计时失效)
Jul 07 Javascript
详解vue+css3做交互特效的方法
Nov 20 Javascript
详解extract-text-webpack-plugin 的使用及安装
Jun 12 Javascript
详解在Node.js中发起HTTP请求的5种方法
Jan 10 Javascript
微信小程序template模板与component组件的区别和使用详解
May 22 Javascript
微信小程序中如何计算距离某个节日还有多少天
Jul 15 Javascript
Vue双向绑定实现原理与方法详解
May 07 Javascript
关于Javascript作用域链的八点总结
Dec 06 #Javascript
Javascript变量作用域详解
Dec 06 #Javascript
JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
Dec 06 #Javascript
Javascript中克隆一个数组的实现代码
Dec 06 #Javascript
浅析JavaScript中的同名标识符优先级
Dec 06 #Javascript
如何判断元素是否为HTMLElement元素
Dec 06 #Javascript
随鼠标上下滚动的jquery代码
Dec 05 #Javascript
You might like
图形数字验证代码
2006/10/09 PHP
php设计模式 Bridge (桥接模式)
2011/06/26 PHP
php实现修改新闻时删除图片的方法
2015/05/12 PHP
php报错502badgateway解决方法
2019/10/11 PHP
关于PHP求解三数之和问题详析
2020/11/09 PHP
PHP7 弃用功能
2021/03/09 PHP
nginx 设置多个站跨域
2021/03/09 Servers
Javascript实现禁止输入中文或英文的例子
2014/12/09 Javascript
解决js页面滚动效果scrollTop在FireFox与Chrome浏览器间的兼容问题的方法
2015/12/03 Javascript
jQuery实现监控页面所有ajax请求的方法
2015/12/10 Javascript
Bootstrap 源代码分析(未完待续)
2016/08/17 Javascript
Bootstrap基本组件学习笔记之列表组(11)
2016/12/07 Javascript
vue.js轮播图组件使用方法详解
2018/07/03 Javascript
ant-design-vue中的select选择器,对输入值的进行筛选操作
2020/10/24 Javascript
基于Vant UI框架实现时间段选择器
2020/12/24 Javascript
深入了解Python数据类型之列表
2016/06/24 Python
python机器学习实战之K均值聚类
2017/12/20 Python
python中pylint使用方法(pylint代码检查)
2018/04/06 Python
keras 特征图可视化实例(中间层)
2020/01/24 Python
详解用Pytest+Allure生成漂亮的HTML图形化测试报告
2020/03/31 Python
python不到50行代码完成了多张excel合并的实现示例
2020/05/28 Python
pytorch 多分类问题,计算百分比操作
2020/07/09 Python
Python实现手绘图效果实例分享
2020/07/22 Python
Python生成并下载文件后端代码实例
2020/08/31 Python
利用Python实现学生信息管理系统的完整实例
2020/12/30 Python
美国购车网站:TrueCar
2016/10/19 全球购物
波兰家具和室内装饰品购物网站:Vivre
2018/04/10 全球购物
英国在线定制百叶窗网站:Swift Direct Blinds
2020/02/25 全球购物
整改报告格式
2014/11/06 职场文书
校车安全管理责任书
2015/05/11 职场文书
2015年度学校卫生工作总结
2015/05/12 职场文书
刑事辩护词范文
2015/05/21 职场文书
《草船借箭》教学反思
2016/02/23 职场文书
青年岗位能手事迹材料(2016推荐版)
2016/03/01 职场文书
Ruby GDBM操作简介及数据存储原理
2022/04/19 Ruby
Python采集壁纸并实现炫轮播
2022/04/30 Python