• 三种简洁的经典高效的DIV+CSS制作的Tab导航简析


    最近做了一个开发感想的网站,想把一些编程中的想法写下来。做网站过程中想做个TAB导航,正好记在这里。也欢迎大家多多访问我的网站

    在网页中应用选项卡可以使网页显得更紧凑,结合AJAX技术可以使页面在有限的空间内展现更多的内容。本文主要介绍几种简洁的选项卡效果的实现(不涉及滑动门和AJAX),附有实例,无图片,兼容性较好,方便大家直接使用。 

    第一种形式: 通过更换显示样式实现,这种很常见,就不多说了。 

    Css代码  收藏代码
    1. <div id="tabs0">  
    2. <ul class="menu0" id="menu0">  
    3.   <li onclick="setTab(0,0)" class="hover">新闻</li>  
    4.   <li onclick="setTab(0,1)">评论</li>  
    5.   <li onclick="setTab(0,2)">技术</li>  
    6.   <li onclick="setTab(0,3)">点评</li>  
    7. </ul>  
    8. <div class="main" id="main0">  
    9.   <ul class="block"><li>新闻列表</li></ul>  
    10.   <ul><li>评论列表</li></ul>  
    11.   <ul><li>技术列表</li></ul>  
    12.   <ul><li>点评列表</li></ul>  
    13. </div>  
    14. </div>  


    第二种形式: 这种结构比较复杂一些,外面加一个相对层(.menu1box),设置溢出隐藏,将选项卡(#menu1)设为绝对定位,设置层指针为1(z-index:1;),以便可以遮住下主区块(.main1box)1px的高度。设置主区块的边框为1px的黑边,上空白(margin-top)为-1px,使上边框伸到选项卡下。当改变选项卡某项(li)的背景为白色时便可遮住一部分主区块的上边框。这样效果就实现了。 

    Css代码  收藏代码
    1. <div id="tabs1">  
    2. <div class="menu1box">  
    3.   <ul id="menu1">  
    4.    <li class="hover" onmouseover="setTab(1,0)"><a href="#">新闻</a></li>  
    5.    <li onmouseover="setTab(1,1)"><a href="#">评论</a></li>  
    6.    <li onmouseover="setTab(1,2)"><a href="#">技术</a></li>  
    7.    <li onmouseover="setTab(1,3)"><a href="#">点评</a></li>  
    8.   </ul>  
    9. </div>  
    10. <div class="main1box">  
    11.   <div class="main" id="main1">  
    12.    <ul class="block"><li>新闻列表</li></ul>  
    13.    <ul><li>评论列表</li></ul>  
    14.    <ul><li>技术列表</li></ul>  
    15.    <ul><li>点评列表</li></ul>  
    16.   </div>  
    17. </div>  
    18. </div>  


    第一、二种形式的JS代码: 

    Js代码  收藏代码
    1. function setTab(m,n){  
    2. var tli=document.getElementById("menu"+m).getElementsByTagName("li"); /*获取选项卡的LI对象*/  
    3. var mli=document.getElementById("main"+m).getElementsByTagName("ul"); /*获取主显示区域对象*/  
    4. for(i=0;i<tli.length;i++){  
    5.   tli[i].className=i==n?"hover":""; /*更改选项卡的LI对象的样式,如果是选定的项则使用.hover样式*/  
    6.   mli[i].style.display=i==n?"block":"none"; /*确定主区域显示哪一个对象*/  
    7. }  
    8. }  


    第三种形式: 这也是一种不常用的方式,加一个相对层(.menu2box),利用一个背景层(#tip2)定位,通过改变层的左距离(left)实现效果。 

    Css代码  收藏代码
      1. <div id="tabs2">  
      2. <div class="menu2box">  
      3.   <div id="tip2"></div>  
      4.   <ul id="menu2">  
      5.    <li class="hover" onmouseover="nowtab(2,0)"><a href="#">新闻</a></li>  
      6.    <li onmouseover="nowtab(2,1)"><a href="#">评论</a></li>  
      7.    <li onmouseover="nowtab(2,2)"><a href="#">技术</a></li>  
      8.    <li onmouseover="nowtab(2,3)"><a href="#">点评</a></li>  
      9.   </ul>  
      10. </div>  
      11.   <div class="main" id="main2">  
      12. 新闻内容 
      13. </div> 
      14. </div> 
  • 相关阅读:
    Rotation Kinematics
    离职 mark
    PnP 问题方程怎么列?
    DSO windowed optimization 代码 (4)
    Adjoint of SE(3)
    IMU 预积分推导
    DSO windowed optimization 代码 (3)
    DSO windowed optimization 代码 (2)
    OKVIS 代码框架
    DSO windowed optimization 代码 (1)
  • 原文地址:https://www.cnblogs.com/xiaochao12345/p/3904388.html
Copyright © 2020-2023  润新知