js里面的变量范围分享


Posted in Javascript onJuly 18, 2020

先上两段代码

<script>
var i = 2;
function test(){
	var i = 1;
}
test();
alert(i);//值为2
</script>
<script>
var i = 2;
function test(){
	i = 1;
}
test();
alert(i);//值为1
</script>

是不是觉得很奇怪,我当时也是这样搞晕了,代码没问题啊,咋回事,最后找了找,原来是var作怪。我自己的理解是,var是用来申明变量的,在方法体里面申明的就是局部变量,局部变量自然不会影响到全局变量的值了。所以第一段代码alert出来的是2;第二段由于没有用var关键词申明,所以默认用的是全局的i的值,在全局里面改变全局变量的值,所以全局变量i的值被修改成1了。

下面再多看几个demo

<script>
/*这个很简单,就是改变全局的值*/
var i = 2;
function test(){
	alert(i);//弹框2
	i = 1;
	alert(i);//弹框1
}
test();
alert(i);//弹框1
</script>
<script>
/*这里就有点奇怪了,为啥第一个alert弹框是undefine呢?*/
var i = 2;
function test(){
	alert(i);//弹框undefined,查了下,这个i不是全局变量,因为在function scope里已经声明了,var i = 1;所以全局的i被覆盖了,这说明了js在执行前会对整个脚本文件的定义部分做完整分析,所以在test()函数执行前,函数体中的变量i都已经被指向了内部的局部变量,而不是指向外部的全局变量,但这是i还没有申明和赋值,所以弹的是undefined。(从刀刀的专栏(http://blog.csdn.net/zyz511919766/article/details/7276089)得知)
	var i = 1;
	alert(i);//弹框1 这里已经赋值了1,然后在函数体里面,所以弹值是1
}
test();
alert(i);//弹框2 因为局部变量不会影响全局变量,所以这里弹的值是2
</script>
<script>
var i =1;
function test(){
	alert(i);//undefined 这个上一段代码已经说了,js会先做解析,只要有var,就会只想局部变量,但是这个时候同样还没定义和赋值,所以undefined
	i=2;
	alert(i)//2 已经赋值了,所以是2
	var i;
	alert(i);//2 这里还是2.因为在前面已经把2赋值给i了
}
test();
alert(i);//1 弹全局的值,毫无疑问
</script>
<script>
/**如果我们方法体里面变量名是一样,但是我又要用到全局的变量怎么办呢**/
var i =1;
function test(){
	var i = 2;
	alert(i);//这里是2,不解释
	alert(window.i);//这里是1 因为用window.globalVariableName方式可以访问到全局的i
}
test();
alert(i);//这里是1,不解释
</script>

解释性文字都写在代码里面,大家搞不懂,可以运行下,就到这了

Javascript 相关文章推荐
javascript 原型模式实现OOP的再研究
Apr 09 Javascript
使用JavaScript库还是自己写代码?
Jan 28 Javascript
cument.execCommand()用法深入理解
Dec 04 Javascript
javascript表单验证 - Parsley.js使用和配置
Jan 25 Javascript
原生JS实现仿淘宝网左侧商品分类菜单效果代码
Sep 10 Javascript
JavaScript获取IP获取的是IPV6 如何校验
Jun 12 Javascript
JavaScript实现经典排序算法之插入排序
Dec 28 Javascript
BootStrap注意事项小结(五)表单
Mar 10 Javascript
js Date()日期函数浏览器兼容问题解决方法
Sep 12 Javascript
mockjs,json-server一起搭建前端通用的数据模拟框架教程
Dec 18 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
Sep 13 Javascript
vscode下的vue文件格式化问题
Nov 28 Javascript
理解Proxy及使用Proxy实现vue数据双向绑定操作
Jul 18 #Javascript
深入理解 ES6中的 Reflect用法
Jul 18 #Javascript
详谈Object.defineProperty 及实现数据双向绑定
Jul 18 #Javascript
webpack+vue-cil 中proxyTable配置接口地址代理操作
Jul 18 #Javascript
Vue项目前后端联调(使用proxyTable实现跨域方式)
Jul 18 #Javascript
完美解决通过IP地址访问VUE项目的问题
Jul 18 #Javascript
Vue移动端项目实现使用手机预览调试操作
Jul 18 #Javascript
You might like
配置支持SSI
2006/11/25 PHP
php小技巧 把数组的键和值交换形成了新的数组,查找值取得键
2011/06/02 PHP
Yii框架中使用PHPExcel的方法分析
2019/07/25 PHP
怎样在JavaScript里写一个swing把数据插入数据库
2012/12/10 Javascript
Microsfot .NET Framework4.0框架 安装失败的解决方法
2013/08/14 Javascript
jquery批量设置属性readonly和disabled的方法
2014/01/24 Javascript
用jQuery toggleClass 实现鼠标移上变色
2014/05/14 Javascript
Node.js中使用事件发射器模式实现事件绑定详解
2014/08/15 Javascript
javascript实现客户端兼容各浏览器创建csv并下载的方法
2015/03/23 Javascript
异步JavaScript编程中的Promise使用方法
2015/07/28 Javascript
详解 javascript中offsetleft属性的用法
2015/11/11 Javascript
Nodejs回调加超时限制两种实现方法
2017/06/09 NodeJs
Node.js  事件循环详解及实例
2017/08/06 Javascript
bootstrap里bootstrap动态加载下拉框的实例讲解
2018/08/10 Javascript
vue watch关于对象内的属性监听
2019/04/22 Javascript
详解小程序如何改变onLoad的执行时机
2019/11/01 Javascript
JS绘图Flot如何实现动态可刷新曲线图
2020/10/16 Javascript
在vue中使用eslint,配合vscode的操作
2020/11/09 Javascript
[01:17:55]VGJ.T vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/20 DOTA
探究Python的Tornado框架对子域名和泛域名的支持
2015/05/02 Python
Windows上使用Python增加或删除权限的方法
2018/04/24 Python
python3通过selenium爬虫获取到dj商品的实例代码
2019/04/25 Python
PyTorch的自适应池化Adaptive Pooling实例
2020/01/03 Python
jupyter 中文乱码设置编码格式 避免控制台输出的解决
2020/04/20 Python
Python实现在线批量美颜功能过程解析
2020/06/10 Python
浅谈多卡服务器下隐藏部分 GPU 和 TensorFlow 的显存使用设置
2020/06/30 Python
使用Python实现音频双通道分离
2020/12/25 Python
幼师专业毕业生自荐信
2013/09/29 职场文书
银行学习十八大感想
2014/01/11 职场文书
初中生操行评语大全
2014/04/24 职场文书
2016年社区文体活动总结
2016/04/06 职场文书
MySQL Shell import_table数据导入的实现
2021/08/07 MySQL
Mysql存储过程、触发器、事件调度器使用入门指南
2022/01/22 MySQL
深入理解go缓存库freecache的使用
2022/02/15 Golang
关于Python中进度条的六个实用技巧分享
2022/04/05 Python
mysql数据库实现设置字段长度
2022/06/10 MySQL