tab页签通常适用于空间有限而内容较多同时兼顾页面美观度不给用户一种信息过量视觉疲劳的情形。使用面非常广,下面我们用两种方法简单实现之。
首先,构建页面元素。页签的可点击部分我们通常用列表来承载,包括ul和ol,我们这里让页签呈横向分布,所以需要使之向左浮动。而页签内容部分使用div承载即可。另外,我们需要对具有共性的元素统一控制样式和行为,所以就有了下面的dom结构:
02 | < ul id = "tabbar" class = "cl" > |
03 | < li class = "t1" >t1</ li > |
04 | < li class = "def" >t2</ li > |
05 | < li class = "def" >t3</ li > |
06 | < li class = "def" >t4</ li > |
07 | < li class = "def" >t5</ li > |
10 | < div class = "cont t1" >Hi !</ div > |
11 | < div class = "cont t2" >I Like You!</ div > |
12 | < div class = "cont t3" >Hello World!</ div > |
13 | < div class = "cont t4" >How Are You?</ div > |
14 | < div class = "cont t5" >I'm fine ,and you?</ div > |
ul左浮动以后,为了清除浮动对后续元素的影响,所以通过after伪类设置clear属性,同时兼顾ie低版本加入zoom触发ie haslayout。所以就有了下面的样式:
01 | html,body,div,ul,li{margin:0; padding:0; } |
04 | .cl:after{display:block; height:0; clear:both; visibility:hidden; overflow:hidden; content:'.';} |
07 | body{padding-top:100px; background:#eee; font-family:Microsoft YaHei, Arial, Helvetica, sans-serif;} |
08 | #main{margin:0 auto; width:800px;} |
10 | #main #tabbar li,#main #content .cont{text-align:center; color:#fff;} |
11 | #main #tabbar li{padding:0 20px; height:35px; line-height:35px; font-size:14px; cursor:pointer; float:left;} |
12 | #main #content{height:350px; overflow:hidden; position:relative;} |
13 | #main #content .cont{width:100%; height:350px; line-height:350px; font-size:48px; z-index:0; position:absolute;} |
15 | #main #tabbar li.def{color:#333; background:#fff;} |
16 | #main #tabbar li.t1,#main #content .cont.t1{color:#fff; background:#4e6b9c;} |
17 | #main #tabbar li.t2,#main #content .cont.t2{color:#fff; background:#c52946;} |
18 | #main #tabbar li.t3,#main #content .cont.t3{color:#fff; background:#33a6ff;} |
19 | #main #tabbar li.t4,#main #content .cont.t4{color:#fff; background:#ffab4e;} |
20 | #main #tabbar li.t5,#main #content .cont.t5{color:#fff; background:#64bccc;} |
html部分大致如此。
采用原生js实现时,我们这里主要对每个li分别绑定点击事件,通过点击使当前内容页显示,其他内容页隐藏,显隐的过程通过定时器不断增减内容的透明度直至完全隐藏或显示。
01 | window.onload = function(){ |
02 | var tabs = document.getElementById("tabbar").getElementsByTagName("li"); |
03 | var cont = document.getElementById("content").getElementsByTagName("div"); |
04 | var len = cont.length; |
07 | var fade = function(elem, callback, type){ |
08 | type || (type = "in"); |
14 | timer = setInterval(function(){ |
18 | elem.style.opacity ? (elem.style.opacity = (px / 100)) : (elem.style["filter"] = "alpha(opacity=" + px + ")"); |
23 | elem.style.opacity ? (elem.style.opacity = 1) : (elem.style["filter"] = "alpha(opacity=100)"); |
24 | callback && callback(elem); |
31 | timer = setInterval(function(){ |
35 | document.addEventListener ? (elem.style.opacity = (px / 100)) : (elem.style["filter"] = "alpha(opacity=" + px + ")"); |
40 | elem.style.opacity ? (elem.style.opacity = 0) : (elem.style["filter"] = "alpha(opacity=0)"); |
41 | callback && callback(elem); |
47 | for(var i = 0; i < len; i++) |
49 | cont[i].style.zIndex = len - i; |
50 | tabs[i].index = cont[i].index = i; |
51 | tabs[i].onclick = function(){ |
55 | cont[this.index].style.display = "block"; |
56 | fade(cont[this.index]); |
57 | for(var i = 0; i < len; i++) |
59 | tabs[i].className = "def"; |
60 | if(tabs[i].index != this.index) |
67 | elem.style.display = "none"; |
68 | elem.className = "cont t" + (elem.index + 1); |
75 | this.className = "t" + (this.index + 1); |
由上可见,其实使用原生js操作dom还是比较麻烦的,不然“write less,do more”的jQuery也不会诞生。下面用jQuery简单实现:
02 | var tabs = $("#tabbar li"); |
03 | var cont = $("#content .cont"); |
04 | var len = cont.length; |
06 | cont.each(function(inx, elem){$(elem).css("z-index", len - inx);}).andSelf().hide().andSelf().eq(1).show(); |
08 | tabs.click(function(){ |
09 | var inx = tabs.index(this); |
10 | tabs.removeAttr("class").addClass("def").andSelf().eq(inx + 1).addClass("t" + (inx + 1)); |
11 | cont.fadeOut(300).not(this).andSelf().eq(inx).fadeIn(300); |
这个例子比较简单,但却很实用,当然实际工作中我们一般不会这样去写,我们通常会把以此为基础去封装一个可重用的控件,但基本思想不变。
代码下载