作家
登录

javascript实现tabs选项卡切换效果(扩展版)

作者: 来源:www.28hudong.com 2013-03-29 23:09:10 阅读 我要评论

前段时间写了个tabs 选项卡切换效果,今天抽空在原有的基础上进行了扩展,加入了自动轮播,这样就变成了类似图片轮播的效果了。 html 代码: 复制代码 代码如下: <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8"> <title>js-tabs</title> <link rel="stylesheet" type="text/css" href="../css/base.css" media="all"/> <style type="text/css"> a{color:#a0b3d6;} .tabs{border:1px solid #a0b3d6;margin:100px;width:300px;} .tabs-nav a{background:#eaf0fd;line-height:30px;padding:0 20px;display:inline-block;border-right:1px solid #a0b3d6;border-bottom:1px solid #a0b3d6;float:left;} .tabs-nav .select1,.tabs-nav .select2,.tabs-nav .select3,.tabs-nav .select4{background:white;border-bottom:1px solid white;_position:relative;} .tabs-content{padding:20px;border-top:1px solid #a0b3d6;margin-top:-1px;} </style> </head> <body> <div class="tabs" id="tabs"> <h2 class="tabs-nav clearfix"> <a href="javascript:;">首页</a> <a href="javascript:;">技术</a> <a href="javascript:;">生活</a> <a href="javascript:;">作品</a> </h2> <p class="tabs-content">首页首页首页首页首页首页首页首页首页首页</p> <p class="tabs-content">技术技术技术技术技术技术技术技术技术技术</p> <p class="tabs-content">生活生活生活生活生活生活生活生活生活生活</p> <p class="tabs-content">作品作品作品作品作品作品作品作品作品作品</p> </div> <br/><br/> <div class="tabs" id="tabs2"> <h2 class="tabs-nav clearfix"> <a href="javascript:;">11111</a> <a href="javascript:;">22222</a> <a href="javascript:;">33333</a> </h2> <p class="tabs-content">11111111111111111111111111111111111</p> <p class="tabs-content ">222222222222222222222222222222222222</p> <p class="tabs-content ">333333333333333333333333333333333333333</p> </div> </body> </html> <script type="text/javascript" src="tabs.js"></script> <script type="text/javascript"> window.onload = function(){ tabs('tabs','click',true,1000); tabs('tabs2','mouseover'); } </script> tabs.js 代码: 复制代码 代码如下: function tabs(id,trigger,autoplay,time){ var tabsWrap = document.getElementById(id); var tabsBtn = tabsWrap.getElementsByTagName('h2')[0].getElementsByTagName('a'); var tabsContent = getClass('tabs-content',tabsWrap); var timer = null; var current = 0; show(0); for(var i = 0,len = tabsBtn.length; i < len; i++){ tabsBtn[i].index = i; if(trigger == 'click'){ tabsBtn[i].onclick = function(){ show(this.index); } }else if(trigger == 'mouseover'){ tabsBtn[i].onmouseover = function(){ show(this.index); } } } if(autoplay){ autoPlay(); tabsWrap.onmouseover = function(){ clearInterval(timer); } tabsWrap.onmouseout = function(){ autoPlay(); } } function autoPlay(){ timer = setInterval(function(){ show(current); current++; if(current >= tabsBtn.length){ current = 0; } },time); } function show(n){ current = n; for(var i = 0,len = tabsBtn.length; i < len; i++){ tabsBtn[i].className = ''; tabsContent[i].style.display = 'none'; } tabsBtn[current].className = 'select' + (current + 1); tabsContent[current].style.display = 'block'; } function getClass(classname,obj){ var results = []; var elems = obj.getElementsByTagName('*'); for(var i = 0; i < elems.length; i++){ if(elems[i].className.indexOf(classname) != -1){ results[results.length] = elems[i]; } } return results; } } PS:这是本人闲着无聊,通过自己所学的 javascript 知识,随意写的一些效果。

  推荐阅读

  input输入框的自动匹配(原生代码)

今天看群里有人发起了人人网以前一些面试题,我以前也转载过一些,恰好闲着,挑选一题来做做,练个手。 本题有以下要求: 1. 使用原生代码实现,不可使用任何框架; 2. 对 input框中输入的字符进行匹配,将匹配到的>>>详细阅读


本文标题:javascript实现tabs选项卡切换效果(扩展版)

地址:http://www.17bianji.com/kaifa2/JS/22208.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)