Heim  >  Artikel  >  Web-Frontend  >  三种简洁的经典高效的DIV+CSS制作的Tab导航简析_html/css_WEB-ITnose

三种简洁的经典高效的DIV+CSS制作的Tab导航简析_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 12:27:19782Durchsuche

在网页中应用选项卡可以使网页显得更紧凑,结合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="brush: 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>

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn