首页 > 语言 > JavaScript > 正文

JS实现选项卡效果的代码实例

2024-05-06 15:39:15
字体:
来源:转载
供稿:网友

选项卡这个效果估计以后的项目会经常涉及到,对代码还是半熟练的情况下还是写下来吧。
先来布局一个简单的页面:

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8">    <title></title>    <style type="text/css">      *{margin: 0;padding: 0;list-style: none;}      #box{margin: 50px;}      #box li{width: 100px;height: 40px;line-height: 40px;text-align: center;background-color: #d8d8d8;margin-right: 2px;float: left;}      #box .active{background: red;}      #content{clear: both;}      #content div{width: 404px;height: 200px;border: 1px solid #d8d8d8;display: none;}    </style>  </head>  <body>    <div id="box">      <!--这个ul为选项卡的菜单,提供选择项,并且设置其中一个li为默认样式-->      <ul>        <li class="active">新闻</li>        <li>社会</li>        <li>科技</li>        <li>娱乐</li>      </ul>      <!--这个div为选项卡的内容,显示不同菜单的不同内容,并且设置其中一个div为可见,其他隐藏-->      <div id="content">        <div style="display: block;">新闻</div>        <div>社会</div>        <div>科技</div>        <div>娱乐</div>      </div>    </div>  </body></html>

选项卡的制作原理是:有若干的选项和对应数量的内容,当对其中一个选项进行操作时,显示对应内容,其他内容不显示。所以,在页面布局的时候,我们先给一个选项设置特殊样式和显示其对应的内容,其他选项样式不变,对应内容隐藏。当操作选项时,把选项的类名改为特殊样式的类名,并且显示对应内容。

<script type="text/javascript">  window.onload=function(){    var oBox=document.getElementById('box');    var aLi=oBox.getElementsByTagName('li');    var oCon=document.getElementById('content');    var aDiv=oCon.getElementsByTagName('div');    for(var i=0;i<aLi.length;i++){      aLi[i].index=i;  //为每个li添加对应的索引index      aLi[i].onclick=function(){  //循环为每个li添加onclick事件      for(var i=0;i<aLi.length;i++){        aLi[i].className=''; //循环清空li样式        aDiv[i].style.display='none'; //循环隐藏所有div      }      this.className='active'; //当前点击的元素样式变成active      aDiv[this.index].style.display='block';  //this.index 获取当前li对应的索引      }    }  }</script>

今天在做选项卡效果时遇到了一个非常低级的错误,但却迟迟找不到原因,如下:
这个是我布局的选项卡的菜单,看起来很简单,一个ul包着3个li,其中一个是 |,所以可以点击的菜单项只有两项,没毛病。

<ul id="text">  <li class="active"><a href="javascript:" rel="external nofollow" rel="external nofollow" >必备软件</a></li>  <li id="shu">|</li>  <li><a href="javascript:" rel="external nofollow" rel="external nofollow" >常用软件</a></li></ul>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选