javascript基础问题,以下代码我想实现tab效果。就是鼠标放在标题1上内容1显示。为什么不行

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/... <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
#content div{display:none;}
</style>
</head>

<body>
<div id="title">
<ul>
<li>标题1</li>
<li>标题2</li>
<li>标题3</li>
</ul>
</div>

<div id="content">
<div>内容1</div>
<div>内容2</div>
<div>内容3</div>
</div>
<script>
var title=document.getElementById("title");
var arrli=title.getElementsByTagName("li");
var content=document.getElementById("content");
var arrpara=content.getElementsByTagName("div");
for(i=0;i<arrli.length;i++){
arrli[i].onmouseover=(function(num){
for(k=0;k<arrpara.length;k++){
arrpara[k].style.display="none"
}
arrpara[num].style.display="block";
})(i)
}
</script>
</body>
</html>
展开
 我来答
cs903016
2014-10-28 · TA获得超过1179个赞
知道小有建树答主
回答量:2599
采纳率:80%
帮助的人:1733万
展开全部
看了下你的代码大概是for循环有问题!改用下面的应该就可以,未测试!
for(i=0;i<arrli.length;i++){
    arrli[i].onmouseover=(function(num){
        return function(){
             for(k=0;k<arrpara.length;k++){
                 arrpara[k].style.display="none"    
              }
              arrpara[num].style.display="block";
           }
        }
    )(i)
}
追问
谢谢,我想问下我上面错误的代码到底是哪里错了啊,和下面这个有区别吗,都是立即执行的啊

var arr=[];
for(i=0;i
追答
好好的看下javascript闭包的概念!
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式