js鼠标点击版tab切换

简介: 代码很简单,主要是布局需要用心研究下,使用时需要把css内注释去除 DOCTYPE html> tab切换 *{margin:0; padding:0;} .tab{width:298px; height:200px; border:1px solid #e5e5e5; ma...

代码很简单,主要是布局需要用心研究下,使用时需要把css内注释去除

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>tab切换</title>
<style>
*{margin:0; padding:0;}
.tab{width:298px; height:200px; border:1px solid #e5e5e5; margin:50px auto;}
a{text-decoration:none; color:#000;}
.tab-tit{height:27px; background:#f8f8f8; position:relative;}                            //定义高度
.tab-tit ul{ list-style-type:none; position:absolute; left:-1px; width:301px;}                        //绝对定位
.tab-tit ul li{float:left; width:58px; text-align:center; line-height:27px;              
border-bottom:1px solid #e5e5e5; padding:0 1px}                 //和tit一样的高度,但是多了一个下边框   左右有1px的内边距防止active加border后布局混乱
.tab-tit ul .active{border-bottom:#fff; background:#fff; border-left:1px solid #e5e5e5; border-right:1px solid #e5e5e5; padding:0;}  
.tab-content div{display:none;}
</style>
<script>
function getByClass(className,parent){
    var oParent=parent?document.getElementById(parent):document;   // 判断parent参数是否存在,不存在,使用document选区文档所有class
    eles=[];                                                   
    elements=oParent.getElementsByTagName('*');
    for(var i=0,l=elements.length;i<l;i++){
        if(elements[i].className==className){                     
            eles.push(elements[i]);                               //所有符合class存入数组,使用是要使用数组形势如 oDiv[0]
        }
    }
    return eles;
}
window.onload=function(){
    var oTab=getByClass('tab-tit');
    var aTab= oTab[0].getElementsByTagName('li');
    var oTabCon=getByClass('tab-content');
    var aTabCon=oTabCon[0].getElementsByTagName('div');
    console.log(aTabCon);
    for(var i=0,l=aTab.length;i<l;i++){
       aTab[i].index=i;                                      //一组元素控制另一组元素,需要加索引
       aTab[i].onclick=function(){
           for(var i=0,l=aTab.length;i<l;i++){
               aTab[i].className='';
           }
           this.className='active';
           
           for(var i=0,l=aTabCon.length;i<l;i++){
                aTabCon[i].style.display='none';
               
           }
           aTabCon[this.index].style.display='block';
           
       }    
    }
}
</script>
</head>

<body>
<div class="tab">
  <div class="tab-tit">
    <ul>
      <li class="active"><a href="javascript:;">关羽</a></li>
      <li><a href="javascript:;">张飞</a></li>
      <li><a href="javascript:;">赵云</a></li>
      <li><a href="javascript:;">马超</a></li>
      <li><a href="javascript:;">黄忠</a></li>
    </ul>
  </div>
  <div class="tab-content">
       <div style="display:block">关羽的儿子</div>
       <div>张飞的儿子</div>
       <div>赵云的儿子</div>
       <div>马超的儿子</div>
       <div>黄忠的儿子</div>
  </div>
</div>
</body>
</html>

感谢Amy老师的教程http://www.imooc.com/learn/176

相关文章
|
6天前
|
存储 JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果+1
JavaScript编程实现tab选项卡切换的效果+1
|
6天前
|
JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果
JavaScript编程实现tab选项卡切换的效果
|
11天前
|
JavaScript 前端开发
JS判断点击是单击还是双击
如何使用JavaScript判断用户点击是单击还是双击。
28 0
|
2月前
|
JavaScript 前端开发 Java
JavaScript内存泄露大揭秘!你的应用为何频频“爆内存”?点击解锁救星秘籍!
【8月更文挑战第23天】在Web前端开发中,JavaScript是构建动态网页的关键技术。然而,随着应用复杂度增加,内存管理变得至关重要。本文探讨了JavaScript中常见的内存泄露原因,包括意外的全局变量、不当使用的闭包、未清除的定时器、未清理的DOM元素引用及第三方库引发的内存泄露。通过了解这些问题并采取相应措施,开发者可以有效避免内存泄露,提高应用性能。
33 1
|
2月前
|
JavaScript Java
点击按钮,向下添加目录。Java script+jQuery写法
点击按钮,向下添加目录。Java script+jQuery写法
17 1
|
2月前
|
JavaScript Java
分别使用js与jquery写 单击按钮时出现内容 点击删除按钮不会再向下出现
分别使用js与jquery写 单击按钮时出现内容 点击删除按钮不会再向下出现
17 1
|
2月前
|
JavaScript 前端开发
js点击抽奖符合条件触发点击次数
js点击抽奖符合条件触发点击次数
27 1
|
2月前
|
JavaScript 前端开发
Next js:点击登录显示登录表单,点击注册显示注册表单的功能
本文提供了一个Next.js中使用React状态管理实现点击按钮切换显示登录和注册表单的功能示例,包括创建`authform.tsx`组件和在页面组件中引入使用的方法。
|
3月前
|
测试技术 UED
断网之后的页面,Autox.js是点击还是上下滑动比较好?
断网之后的页面,Autox.js是点击还是上下滑动比较好?
|
3月前
|
JavaScript
js 滚动鼠标滑轮放大缩小图片
js 滚动鼠标滑轮放大缩小图片
22 0