JS中局部变量能修改全局变量吗?

*{margin:0; padding:0;}
.box{background:red; font-size:18px; height:20px; overflow:hidden; }
ul{list-style:none; height:0;}
</style>
</head>

<body>
<div class="box" onclick="fun()">第一章</div>
<ul><li>第一节<li><li>第二节</li></ul>
<!--<div class="box" onclick="fun()" >第二章</div>
<ul><li>第一节<li><li>第二节</li></ul>-->
<script type="text/javascript">
oul=document.getElementsByTagName("ul")[0];
oul2=document.getElementsByTagName("ul")[1];

function fun()
{
var i=false;
if(i==true)
{
oul.style.height=40+"px";
oul.style.visibility='visible';
}
else
{
oul.style.visibility='hidden';
oul.style.height=0;
i=true;
}
}
</script>
点击后能隐藏,再次点击后却不能展开。(我的目的是点击隐藏后,将FUN()中的全局变量修改为true,这样就能执行(if==true)了。

一、Javascript的变量的scope是根据方法块来划分的(也就是说以function的一对大括号{ }来划分)。切记,是function块,而for、while、if块并不是作用域的划分标准。

二、
当全局变量跟局部变量重名时,局部变量的scope会覆盖掉全局变量的scope,当离开局部变量的scope后,又重回到全局变量的scope,而当全局变量遇上局部变量时,用window.globalVariableName取全局变量的值。

三、请看下面例子:
<script>
var a =1;
function test(){
alert(window.a); //a为1,这里的a是全局变量哦!
var a=2; //局部变量a在这行定义
alert(a); //a为2,这里的a是局部变量哦!
}
test();
alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
</script>
温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-09-13
把i作为全局变量就可以了。
然后控制条件判断,当i为假时,执行操作后使其变为真;当i为真时,执行操作后使其变为假,这样就能循环了。

var i=false;
function fun()
{
if(i==true)
{
oul.style.height=40+"px";
oul.style.visibility='visible';
i=false;// 要加上这一句,否则该效果不能循环展示
}
else
{
oul.style.visibility='hidden';
oul.style.height=0;
i=true;
}
}本回答被提问者采纳
相似回答