//总结:这个样式的思维很重要,以前刚开始做,想的都是,怎么获取到自己点击的是哪一个li,然后给他以对应的div样式。后来发现难点是,怎么找到另外两个没有被点击的li和他们对应的div。把他们的样式去掉。现在恍然,这种“打扫完屋子再请客”的思维,先把所有的都去掉,再想给谁添加就给谁添加就可以了呀!看来以后,想拿起什么东西前,得先学会把该放下的放下。不然,难为的只有自己。

<!DOCTYPE html>
<html>

<head>

<meta name="author" content"郭菊锋,702004176@qq.com">
<meta charset="UTF-8">
<title>选项卡</title>
<style type="text/css">
* {
margin: 0;
padding: 0;
}

a {
text-decoration: none;
color: black;
}

li {
list-style: none;
}

.tapWrap {
border: 3px dotted #4169E1;
width: 25%;
margin: 10px auto;
padding: 10px;
-webkit-border-radius: 8px;
-moz-border-radius: 8px;
border-radius: 8px;
}

ul.tapHeadWrap li {
width: 75px;
height: 45px;
line-height: 45px;
text-align: center;
display: inline-block;
border: 2px solid #ccc;
background-color: white;
}

.tapWrap div {
width: 94%;
padding: 10px;
margin-top: -4px;
border: 2px solid #ccc;
}
.tapWrap>ul li:hover,
.tapWrap div {
border-top: 3px solid #DC143C;
}
.tapWrap div li{
margin: 5px 0;
}
.tapWrap div a:hover{
text-decoration: underline;
color: #DC143C;
}
.tapWrap>ul li:hover,
.tapWrap div a:hover {
cursor: pointer;
}

ul.tapHeadWrap li.on {
border-top: 3px solid #DC143C;
border-bottom: 7px solid #fff;
}
.hide{
display: none;
}
</style>
</head>

<body>
<div class="tapWrap" ; font-size: 15px'>//这里的tapLi[j]==tapLi[i]的值吗?不等于,这里的作用是让j【也就是从0-2,因为j小于li的长度,j又是从0开始的,所以j就是在0,1,2这三个数上面循环一遍】

//alert(tapLi[j].index);//由此调试循环得出,j分别是0,1,2.对应到html中,就是第一个li、第二个li、第三个li的className都成了0.这样先全部清除掉,到了下边j循环外,this.className处,再把点击的对应的li加上className。
tapDiv[j].className = "hide";//让所有的都先隐藏

 tapDiv[j].style.display = 'none';//对应的这里也就不能再用className了,而要改成style,上一行的className就要删掉
}

//j循环的外边
this.className = "on";//this代指tapLi[i],当前所点击的li,给他添加类名
tapDiv[this.index].className = "";//this.index=tapLi[i].index,具体作用下边alert做调试得知,就是得到一个对应你点击的li的下标(即一个数字),这个数字再搭配tapDiv[]的方式,自然就是获取和当前li对应的div了,因为div的下标也是从0开始共三个数的。这样,给当前被点击li对应的div空类名,去除掉j循环中添加在他身上的hide枷锁,他就得意重见天日了!

//这里最后把className忘记了,害得我调试了半天。记得思维不能忘,就是通过className来更改他的css样式,或者也可以对应上面j循环里,添加隐藏样式那地方(绿色位置)直接更改css样式:如下
tapDiv[this.index].style.display = 'block';

 

//alert(this.index);//调试:得到的是当前被点击的li的下标


    }
  }
}
</script>

<!--清爽js代码如下-->

 1 <script type="text/javascript">
 2         window.onload = function() {
 3             var tapDivWrap = document.getElementById('tapWrap');
 4             var tapDiv = tapDivWrap.getElementsByTagName('div');
 5             var tapUl = document.getElementById('tapHeadWrap');
 6             var tapLi = tapUl.getElementsByTagName('li');
 7             for(var i = 0; i < tapLi.length; i++) {
 8                 tapLi[i].index = i;
 9                 tapLi[i].onclick = function() {
10                     for(var j = 0; j < tapLi.length; j++) {
11                         tapLi[j].className = "";
12                         tapDiv[j].className = "tapHideDiv";
13                     }
14                     this.className = "tapActiveLi";
15                     tapDiv[this.index].className = "";
16                 }
17             }
18         }
19     </script>
View Code

相关文章: