js里面的变量范围分享

作者:键盘钢琴师 时间:2024-04-19 09:51:47 

先上两段代码


<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>

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

来源:https://blog.csdn.net/forLightWay/article/details/50724127

标签:js变量范围
0
投稿

猜你喜欢

  • python命令行模式的用法及流程

    2022-05-01 17:31:13
  • Python入门之布尔值详解

    2023-01-17 06:29:58
  • react+django清除浏览器缓存的几种方法小结

    2022-10-05 03:07:45
  • 关于JavaScript中高阶函数的魅力详解

    2024-04-18 09:29:40
  • PyQt5实现从主窗口打开子窗口的方法

    2023-01-14 11:06:11
  • php 解压zip压缩包内容到指定目录的实例

    2024-04-18 09:28:47
  • Vue之使用mockjs生成模拟数据案例详解

    2024-05-29 22:24:40
  • python编写接口测试文档(以豆瓣搜索为例)

    2023-09-21 17:39:49
  • python list语法学习(带例子)

    2023-08-20 05:36:40
  • python OpenCV图像直方图处理

    2022-05-28 06:31:45
  • pandas时间序列之如何将int转换成datetime格式

    2023-03-09 07:50:34
  • nestjs实现图形校验和单点登录的示例代码

    2024-04-16 09:49:08
  • 利用一个简单的例子窥探CPython内核的运行机制

    2023-08-11 04:54:31
  • Python Pyinstaller库安装步骤以及使用方法

    2021-05-12 07:07:26
  • 使用pytorch提取卷积神经网络的特征图可视化

    2023-02-01 20:32:30
  • 让网站容易被发现

    2009-04-20 20:35:00
  • php实现的支持断点续传的文件下载类

    2023-11-23 16:52:19
  • Linux安装Python3如何和系统自带的Python2并存

    2023-08-25 03:42:09
  • python加速器numba使用详解

    2022-02-27 15:24:22
  • python爬虫的一个常见简单js反爬详解

    2022-10-26 11:46:27
  • asp之家 网络编程 m.aspxhome.com