亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Jquery封裝tab自動切換效果的具體實現

2019-11-20 22:31:36
字體:
來源:轉載
供稿:網友
  今天我這邊網速真是太慢了,打開一個網頁要等待很久,但是還是想寫篇文章----tab自動切換 因為工作中經常會碰到這樣的問題 所以寫博客也是總結下 最重要的是能分享下 及以后碰到類似的可以參考下! 當然這是我用Jquery來封裝的 頁面可以調用多次 調用方式                new tabSlider(obj,count); obj指容器最外層ID,count指有多個li 當然要引用我這個js的話 一定要按照我結構來寫!下面的是我的HTML一些結構如下:
復制代碼 代碼如下:

<div id="tab1">
    <ul class="menu">
        <li class="current">tab1</li>
        <li>tab2</li>
        <li>tab3</li>
        <li class="last-col">tab4</li>
    </ul>
    <div class="content-main">
        <div class="content">tab1</div>
        <div class="content hide">tab2</div>
        <div class="content hide">tab3</div>
        <div class="content hide">tab4</div>
    </div>
</div>

結構是這樣的!下面是我頁面上的HTML/CSS的代碼!
復制代碼 代碼如下:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題文檔</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script>
<style>
#tab1{ width:196px; height:220px; overflow:hidden; border:1px solid #666;}
#tab2{ width:196px; height:220px; overflow:hidden; border:1px solid #666;}
.menu{ width:196px; height:18px; margin:0; padding:0;}
.menu li{ float:left; list-style:none; width:48px; text-align:center; border-bottom:1px solid #666; border-right:1px solid #666; cursor:pointer;}
.menu li.current{ border-bottom:none;}
.content-main{ width:196px; height:200px; overflow:hidden;}
.content{ width:196px; height:200px; overflow:hidden; display:block;}
.hide{ display:none;width:196px; height:200px; overflow:hidden;}
.menu li.last-col{ border-right:none; width:49px;}
</style>
<script src="AutoTab.js"></script>
</head>
<body>
<div id="tab1">
    <ul class="menu">
        <li class="current">tab1</li>
        <li>tab2</li>
        <li>tab3</li>
        <li class="last-col">tab4</li>
    </ul>
    <div class="content-main">
        <div class="content">tab1</div>
        <div class="hide">tab2</div>
        <div class="hide">tab3</div>
        <div class="hide">tab4</div>
    </div>
</div>
<br /><br />
<div id="tab2">
    <ul class="menu">
        <li class="current">tab1</li>
        <li>tab2</li>
        <li>tab3</li>
        <li class="last-col">tab4</li>
    </ul>
    <div class="content-main">
        <div class="content">tab1</div>
        <div class="hide">tab2</div>
        <div class="hide">tab3</div>
        <div class="hide">tab4</div>
    </div>
</div>
<script>new tabSlider("#tab1",4);</script>
<script>new tabSlider("#tab2",4);</script>
</body>
</html>

JS代碼如下:
復制代碼 代碼如下:

// JavaScript Document
    /*
    *@date 2011 10 24
    *@ author tugenhua
    *@ email tugenhua@126.com
    *@ 可以一個頁面多次引用
    依賴的結構 */
    <div id="tab1">
    <ul class="menu">
        <li class="current">tab1</li>
        <li>tab2</li>
        <li>tab3</li>
        <li class="last-col">tab4</li>
    </ul>
    <div class="content-main">
        <div class="content">tab1</div>
        <div class="content hide">tab2</div>
        <div class="content hide">tab3</div>
        <div class="content hide">tab4</div>
    </div>
</div>
/*頁面引用的方式
    new tabSlider("#tab1",4);
    #tab1 是外部ID,4 指 一共有多少個li
*/
function tabSlider(obj,count){
    var _this = this;
        _this.obj = obj;
        _this.count = count;
        _this.time = 2000;//停留的時間
        _this.n = 0;
        var  t;
        this.slider = function(){
            $(_this.obj + " .menu li").bind("mouseover",function(event){
                $(event.target).addClass("current").siblings().removeClass("current");
                var index = $(_this.obj + " .menu li").index(this);
                $(_this.obj + " .content-main .content").eq(index).show().siblings().hide();
                _this.n = index;    
            })  
        }
        this.addhover = function(){
            $(_this.obj).hover(function(){clearInterval(t);},function(){t=setInterval(_this.autoplay,_this.time)}); 
        }
        this.autoplay = function(){
            _this.n = _this.n >=(_this.count-1)? 0 : ++_this.n;
            $(_this.obj + " .menu li").eq(_this.n).trigger("mouseover");    
        }   
        this.factory = function(){
            this.slider();
            this.addhover();
            t = setInterval(this.autoplay,_this.time);  
        }
        this.factory();
}

下面來說說下我封裝這個js的思路,因為寫任何程序 思路是最重要的,只要能想的清楚 代碼就一定能實現掉!思路說的更好聽的話 就是我們常說的“算法”!
1 function tabSlider(obj,count){} 用這個js來封裝后傳入參數!當在HTML頁面上時直接調用tabSlider(obj,count)就可以了!
2 初始化一些參數 然后給這個函數自生自定義一個函數this.slider = function(){} 綁定個mouseover事件,初始化第一個li時 查找當前的div內容是否和當前li 指向同一個指針 如果相同 那塊內容顯示!其他的隱藏!
3 自定義this.addHover這個事件  當鼠標移上時候抽發這個事件!
4 自定義自動播放事件this.autoplay = function(){} 這個里面用了trigger這個觸發方法_this.n = _this.n >=(_this.count-1)? 0 : ++_this.n;
   $(_this.obj + " .menu li").eq(_this.n).trigger("mouseover");
5 最后用個函數 來渲染上面的函數 調用上面的函數
復制代碼 代碼如下:

this.factory = function(){
   this.slider();
   this.addhover();
   t = setInterval(this.autoplay,_this.time);
  }
  this.factory();
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情乱人伦一区| 亚洲第一精品夜夜躁人人躁| 亚洲香蕉成视频在线观看| 性欧美亚洲xxxx乳在线观看| 亚洲精品美女网站| 日韩精品在线看| 欧美专区第一页| 久久男人的天堂| 97精品国产91久久久久久| 日韩亚洲成人av在线| 国产精品爽爽爽| 国产精品久久久久av| 97在线精品国自产拍中文| 久久亚洲综合国产精品99麻豆精品福利| 色综合久久中文字幕综合网小说| 久久久99久久精品女同性| 欧美自拍大量在线观看| 蜜臀久久99精品久久久无需会员| 久久久久久久久亚洲| 日韩毛片在线观看| 欧美性xxxxhd| 亚洲欧美中文日韩在线| 国产伦精品一区二区三区精品视频| 日本亚洲精品在线观看| 国产精品国产三级国产aⅴ浪潮| 久久深夜福利免费观看| 亚洲国产另类久久精品| 久久久久久久97| 亚洲成人精品久久| 91精品视频在线看| 国产亚洲精品久久久久久777| 久久久爽爽爽美女图片| 日韩视频在线观看免费| 久久影院资源站| 久久久99久久精品女同性| 久久中文字幕在线视频| 久久久久久久一区二区三区| 日韩亚洲欧美成人| 日韩中文字幕在线免费观看| 国产精品一区二区在线| 久久久欧美一区二区| 亚洲福利视频在线| 国产欧美 在线欧美| 久久精品影视伊人网| 国产精品久久久久福利| 久久久av一区| 免费91麻豆精品国产自产在线观看| 欧美伊久线香蕉线新在线| 亚洲精品91美女久久久久久久| 中文字幕日韩视频| 亚洲一区二区三区在线免费观看| 国产精品青草久久久久福利99| 国产精品成人免费视频| 裸体女人亚洲精品一区| 国产日产欧美a一级在线| 欧美性xxxx在线播放| 国产精品永久免费| 久久69精品久久久久久国产越南| 91九色视频导航| 国产精品视频一区二区高潮| 91精品综合久久久久久五月天| 久久99精品国产99久久6尤物| 国产激情综合五月久久| 国产午夜精品久久久| 国产原创欧美精品| 色播久久人人爽人人爽人人片视av| 国产这里只有精品| 久久在线免费观看视频| 欧美在线激情视频| 日韩欧美福利视频| 亚洲黄色片网站| 欧美性生交xxxxx久久久| 国产日本欧美一区二区三区| 伊人精品在线观看| 色噜噜狠狠色综合网图区| 亚洲欧美在线一区二区| 欧美在线观看视频| 国产精品久久久久久av福利软件| 最好看的2019的中文字幕视频| 亚洲人成在线一二| 欧美男插女视频| 久久精品国产欧美激情| 一区二区欧美激情| 亚洲精品国产免费| 亚洲午夜精品久久久久久久久久久久| 欧美日本啪啪无遮挡网站| 欧美大片欧美激情性色a∨久久| 日本亚洲精品在线观看| 欧美日韩电影在线观看| 亚洲人成网站777色婷婷| 国产精品老牛影院在线观看| 欧美一级免费视频| 国产在线精品播放| 国产成人精品优优av| 久久男人资源视频| 日韩中文字幕免费看| 欧美国产日韩一区二区三区| 欧美午夜精品久久久久久人妖| 大桥未久av一区二区三区| 精品人伦一区二区三区蜜桃免费| 免费不卡在线观看av| 国产精品青草久久久久福利99| 精品国产区一区二区三区在线观看| 欧美日韩色婷婷| 精品亚洲一区二区三区在线播放| 欧美极品少妇xxxxⅹ免费视频| 91精品视频播放| 亚洲国产成人精品女人久久久| 91精品在线观看视频| 精品国产一区二区在线| 夜夜嗨av色综合久久久综合网| 欧美日韩国产精品一区二区三区四区| 亚洲码在线观看| 欧美日韩免费在线| 国产精品jvid在线观看蜜臀| 欧美性高潮床叫视频| 97成人精品视频在线观看| 欧美精品激情blacked18| 91免费精品国偷自产在线| 蜜臀久久99精品久久久久久宅男| 欧美精品中文字幕一区| 久久国产加勒比精品无码| 国产精品成人一区| 26uuu另类亚洲欧美日本老年| 久久久精品免费| 欧美大片在线免费观看| 98午夜经典影视| 91情侣偷在线精品国产| 国语自产精品视频在线看一大j8| 91在线播放国产| 国产精品av在线播放| 国产精品丝袜久久久久久高清| 黑人巨大精品欧美一区二区一视频| 亚洲精品大尺度| 国产日韩欧美成人| 亚洲精品视频在线播放| 成人免费网站在线观看| 韩国三级电影久久久久久| 亚洲精品在线视频| 欧美xxxx18国产| 黑人巨大精品欧美一区二区三区| 亚洲精品国偷自产在线99热| 亚洲国内高清视频| 成人欧美一区二区三区黑人| 国产欧美最新羞羞视频在线观看| 日韩有码在线播放| 国产精品久久综合av爱欲tv| 亚洲第一精品夜夜躁人人躁| 久久久久久国产精品三级玉女聊斋| 全色精品综合影院| 国产精品一二三在线| 欧美性猛交xxxx乱大交极品| 亚洲电影免费观看| 国产成人精彩在线视频九色| 精品爽片免费看久久| 韩国日本不卡在线| 久久综合免费视频影院| 亚洲精品在线不卡| 久久久国产一区二区三区| 国产成人精品在线观看| 国产精品男人的天堂| 久久久久久美女| 日韩av网址在线观看| 国产精品国语对白|