【javascript】tabs 选项卡切换效果(扩展版)

前段时间写了个 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;
    }
}
原文地址:https://www.cnblogs.com/yjzhu/p/2856867.html