js里面的变量范围分享
网络编程 2021-07-04 14:06www.168986.cn编程入门
今天写一个滑动自动加载的功能的时候,遇到了切换就发现加载完毕的情况,查看了下发现可能是js的全局变量和局部变量的问题,自己测试了下,果不其然,狼蚁网站SEO优化分享下
先上两段代码
<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了。
狼蚁网站SEO优化再多看几个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./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>
解释性文字都写在代码里面,大家搞不懂,可以运行下,就到这了
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程