Jquery封裝tab自動切換效果 – Javascript教程_JS教程_技術文章 – 程式設計聯盟

 

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

 

<p id="tab1">

    <ul class="menu">

        <li class="current">tab1</li>

        <li>tab2</li>

        <li>tab3</li>

        <li class="last-col">tab4</li>

    </ul>

    <p class="content-main">

        <p class="content">tab1</p>

        <p class="content hide">tab2</p>

        <p class="content hide">tab3</p>

        <p class="content hide">tab4</p>

    </p>

</p>

 

結構是這樣的!下面是我頁面上的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>

 

<p id="tab1">

    <ul class="menu">

        <li class="current">tab1</li>

        <li>tab2</li>

        <li>tab3</li>

        <li class="last-col">tab4</li>

    </ul>

    <p class="content-main">

        <p class="content">tab1</p>

        <p class="hide">tab2</p>

        <p class="hide">tab3</p>

        <p class="hide">tab4</p>

    </p>

</p>

<br /><br />

 

<p id="tab2">

    <ul class="menu">

        <li class="current">tab1</li>

        <li>tab2</li>

        <li>tab3</li>

        <li class="last-col">tab4</li>

    </ul>

    <p class="content-main">

        <p class="content">tab1</p>

        <p class="hide">tab2</p>

        <p class="hide">tab3</p>

        <p class="hide">tab4</p>

    </p>

</p>

<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 

    *@ 可以一個頁面多次引用 

    依賴的結構 

    <p id="tab1"> 

    <ul class="menu"> 

        <li class="current">tab1</li> 

        <li>tab2</li> 

        <li>tab3</li> 

        <li class="last-col">tab4</li> 

    </ul> 

    <p class="content-main"> 

        <p class="content">tab1</p> 

        <p class="content hide">tab2</p> 

        <p class="content hide">tab3</p> 

        <p class="content hide">tab4</p> 

    </p> 

</p> 

 

×頁面引用的方式 

    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時 查找當前的p內容是否和當前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 最後用個函數 來渲染上面的函數 調用上面的函數 www.aiwalls.com

this.factory = function(){

   this.slider();

   this.addhover();

   t = setInterval(this.autoplay,_this.time);

  }

  this.factory();

本文出自 “塗根華前端博客” 博客

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *