zoukankan      html  css  js  c++  java
  • 三种简洁的经典高效的DIV+CSS制作的Tab导航简析

    在网页中应用选项卡可以使网页显得更紧凑,结合AJAX技术可以使页面在有限的空间内展现更多的内容。本文主要介绍几种简洁的选项卡效果的实现(不涉及滑动门和AJAX),附有实例,无图片,兼容性较好,方便大家直接使用。 第一种形式: 通过更换显示样式实现,这种很常见,就不多说了。
    <div id="tabs0">
    <ul class="menu0" id="menu0">
      <li onclick="setTab(0,0)" class="hover">新闻</li>
      <li onclick="setTab(0,1)">评论</li>
      <li onclick="setTab(0,2)">技术</li>
      <li onclick="setTab(0,3)">点评</li>
    </ul>
    <div class="main" id="main0">
      <ul class="block"><li>新闻列表</li></ul>
      <ul><li>评论列表</li></ul>
      <ul><li>技术列表</li></ul>
      <ul><li>点评列表</li></ul>
    </div>
    </div>
    
    第二种形式: 这种结构比较复杂一些,外面加一个相对层(.menu1box),设置溢出隐藏,将选项卡(#menu1)设为绝对定位,设置层指针为1(z-index:1;),以便可以遮住下主区块(.main1box)1px的高度。设置主区块的边框为1px的黑边,上空白(margin-top)为-1px,使上边框伸到选项卡下。当改变选项卡某项(li)的背景为白色时便可遮住一部分主区块的上边框。这样效果就实现了。
    <div id="tabs1">
    <div class="menu1box">
      <ul id="menu1">
       <li class="hover" onmouseover="setTab(1,0)"><a href="#">新闻</a></li>
       <li onmouseover="setTab(1,1)"><a href="#">评论</a></li>
       <li onmouseover="setTab(1,2)"><a href="#">技术</a></li>
       <li onmouseover="setTab(1,3)"><a href="#">点评</a></li>
      </ul>
    </div>
    <div class="main1box">
      <div class="main" id="main1">
       <ul class="block"><li>新闻列表</li></ul>
       <ul><li>评论列表</li></ul>
       <ul><li>技术列表</li></ul>
       <ul><li>点评列表</li></ul>
      </div>
    </div>
    </div>
    
    第一、二种形式的JS代码:
    function setTab(m,n){
    var tli=document.getElementById("menu"+m).getElementsByTagName("li"); /*获取选项卡的LI对象*/
    var mli=document.getElementById("main"+m).getElementsByTagName("ul"); /*获取主显示区域对象*/
    for(i=0;i<tli.length;i++){
      tli[i].className=i==n?"hover":""; /*更改选项卡的LI对象的样式,如果是选定的项则使用.hover样式*/
      mli[i].style.display=i==n?"block":"none"; /*确定主区域显示哪一个对象*/
    }
    }
    
    第三种形式: 这也是一种不常用的方式,加一个相对层(.menu2box),利用一个背景层(#tip2)定位,通过改变层的左距离(left)实现效果。
    
    <pre class=" html; gutter: true; first-line: 1; highlight: []; html-script: false">
    <div id="tabs2">
    <div class="menu2box">
      <div id="tip2"></div>
      <ul id="menu2">
       <li class="hover" onmouseover="nowtab(2,0)"><a href="#">新闻</a></li>
       <li onmouseover="nowtab(2,1)"><a href="#">评论</a></li>
       <li onmouseover="nowtab(2,2)"><a href="#">技术</a></li>
       <li onmouseover="nowtab(2,3)"><a href="#">点评</a></li>
      </ul>
    </div>
      <div class="main" id="main2">
    新闻内容
    </div>
    </div>
    
  • 相关阅读:
    Python元组、列表、字典
    测试通过Word直接发布博文
    Python环境搭建(windows)
    hdu 4003 Find Metal Mineral 树形DP
    poj 1986 Distance Queries LCA
    poj 1470 Closest Common Ancestors LCA
    poj 1330 Nearest Common Ancestors LCA
    hdu 3046 Pleasant sheep and big big wolf 最小割
    poj 3281 Dining 最大流
    zoj 2760 How Many Shortest Path 最大流
  • 原文地址:https://www.cnblogs.com/AS30/p/3113267.html
Copyright © 2011-2022 走看看