欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery隊列操作方法實例

 更新時間:2014年06月11日 08:36:46   作者:  
這篇文章主要介紹了jQuery隊列操作方法實例,總結(jié)出了一個簡潔優(yōu)雅的隊列控制方法,需要的朋友可以參考下

jQuery核心中, 有一組隊列控制方法, 這組方法由queue()/dequeue()/clearQueue()三個方法組成, 它對需要連續(xù)按序執(zhí)行的函數(shù)的控制可以說是簡明自如, 主要應用于animate ()方法, ajax以及其他要按時間順序執(zhí)行的事件中.

先解釋一下這組方法各自的含義.

queue(name,[callback]): 當只傳入一個參數(shù)時, 它返回并指向第一個匹配元素的隊列(將是一個函數(shù)數(shù)組,隊列名默認是fx); 當有兩個參數(shù)傳入時, 第一個參數(shù)還是默認為fx的的隊列名, 第二個參數(shù)又分兩種情況, 當?shù)诙€參數(shù)是一個函數(shù)時, 它將在匹配的元素的隊列最后添加一個函數(shù). 當?shù)诙€參數(shù)是一個函數(shù)數(shù)組時,它將匹配元素的隊列用新的一個隊列來代替(函數(shù)數(shù)組).可能, 這個理解起來有點暈.

dequeue(name): 這個好理解, 就是從隊列最前端移除一個隊列函數(shù), 并執(zhí)行它.

clearQueue([queueName]):這是1.4新增的方法. 清空對象上尚未執(zhí)行的所有隊列. 參數(shù)可選,默認為fx. 但個人覺得這個方法沒多大用, 用queue()方法傳入兩個參數(shù)的第二種參數(shù)即可實現(xiàn)clearQueue方法.

現(xiàn)在, 我們要實現(xiàn)這樣一個效果, 有標有1至7的數(shù)字方塊, 要求這七個方塊自左到右依次下落. 查看DEMO
css與html部分我就不貼出來了, DEMO中有. 若按常規(guī)做法, 可能需要用如下jQ代碼來實現(xiàn):

復制代碼 代碼如下:

$('.one').delay(500).animate({
    top: '+=270px'
},
500,
function() {
    $('.two').delay(500).animate({
        top: '+=270px'
    },
    500,
    function() {
        $('.three').delay(500).animate({
            top: '+=270px'
        },
        500,
        function() {
            $('.four').delay(500).animate({
                top: '+=270px'
            },
            500,
            function() {
                $('.five').delay(500).animate({
                    top: '+=270px'
                },
                500,
                function() {
                    $('.six').delay(500).animate({
                        top: '+=270px'
                    },
                    500,
                    function() {
                        $('.seven').animate({
                            top: '+=270px'
                        },
                        500,
                        function() {
                            alert('按序落體運動結(jié)束! Yeah!')
                        });
                    });
                });
            });
        });
    });
});


嗯, 沒錯, 效果很完美的呈現(xiàn)給出來了, 但這種暈眩的代碼, 你能忍受嗎? 即便可以忍受, 如果此時, 你想調(diào)換一個某個的執(zhí)行順序, 比如, 你想讓5落下后再開始下落3, 或者新加8至15八個方塊, 怎么辦? 重寫嗎? 在里面小心冀冀的改嗎? 顯然, 我們需要另外一種列簡明便捷的方法來實現(xiàn)這個效果, 那就是jQuery隊列控制方法.請看如下代碼:

復制代碼 代碼如下:

var _slideFun = [function() {
    $('.one').delay(500).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.two').delay(300).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.three').delay(300).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.four').delay(300).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.five').delay(300).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.six').delay(300).animate({
        top: '+=270px'
    },
    500, _takeOne);
},
function() {
    $('.seven').delay(300).animate({
        top: '+=270px'
    },
    500,
    function() {
        alert('按序落體運動結(jié)束! Yeah!');
    });
}];
$('#demo').queue('slideList', _slideFun);
var _takeOne = function() {
    $('#demo').dequeue('slideList');
};
_takeOne();


這樣一來, 看起來是不是簡明多了. 如何實現(xiàn)?
1. 新建一個數(shù)組,把動畫函數(shù)依次放進去(這樣更改順序,新加動畫是不是方便多了?);
2. 用queue將這組動畫函數(shù)數(shù)組加入到slideList隊列中;
3. 用dequeue取出slideList隊列中第一個函數(shù), 并執(zhí)行它;
4. 初始執(zhí)行第一個函數(shù).

至于clearQueue()方法,就不多說了, 演示中停止按鈕調(diào)用的就是clearQueue()方法,當然你還可以用queue()方法直接將現(xiàn)在的函數(shù)列隊替換成[]空數(shù)組實現(xiàn)(個人比較推薦空數(shù)組替換.,更直觀).

相關(guān)文章

  • Jquery實現(xiàn)獲取子元素的方法分析

    Jquery實現(xiàn)獲取子元素的方法分析

    這篇文章主要介紹了Jquery實現(xiàn)獲取子元素的方法,結(jié)合實例形式分析了jQuery針對頁面元素的查找、獲取相關(guān)操作技巧,需要的朋友可以參考下
    2019-08-08
  • jquery實現(xiàn)簡單的swiper輪播預覽原圖

    jquery實現(xiàn)簡單的swiper輪播預覽原圖

    這篇文章主要為大家詳細介紹了jquery實現(xiàn)簡單的swiper輪播預覽原圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • jquery實現(xiàn)拖拽table表頭改變列寬

    jquery實現(xiàn)拖拽table表頭改變列寬

    這篇文章主要為大家詳細介紹了jquery實現(xiàn)拖拽table表頭改變列寬,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • jQuery實現(xiàn)3D文字特效的方法

    jQuery實現(xiàn)3D文字特效的方法

    這篇文章主要介紹了jQuery實現(xiàn)3D文字特效的方法,通過鼠標與css樣式來實現(xiàn)文字特效的技巧,需要的朋友可以參考下
    2015-03-03
  • JSON JQUERY模板實現(xiàn)說明

    JSON JQUERY模板實現(xiàn)說明

    用JSON從服務器端返回數(shù)據(jù)已是大家公認的標準,因為它短小精悍,使用方便.
    2010-07-07
  • jquery分頁優(yōu)化操作實例分析

    jquery分頁優(yōu)化操作實例分析

    這篇文章主要介紹了jquery分頁優(yōu)化操作,在前文jQuery分頁顯示的基礎(chǔ)上實現(xiàn)了避免頻繁查詢的相關(guān)優(yōu)化操作技巧,需要的朋友可以參考下
    2019-08-08
  • jQuery表單驗證功能實例

    jQuery表單驗證功能實例

    這篇文章主要介紹了jQuery表單驗證功能,涉及jquery針對表單項的讀取與正則判定技巧,非常具有實用價值,需要的朋友可以參考下
    2015-08-08
  • 基于jQuery和Bootstrap框架實現(xiàn)仿知乎前端動態(tài)列表效果

    基于jQuery和Bootstrap框架實現(xiàn)仿知乎前端動態(tài)列表效果

    最近基于jQuery和Bootstrap框架實現(xiàn)了一個仿知乎動態(tài)列表的前端效果,基本實現(xiàn)了和知乎動態(tài)列表相同的效果,下面小編通過本文給大家分享實現(xiàn)思路及代碼,對bootstrap 實現(xiàn)仿知乎前端動態(tài)列表效果感興趣的朋友一起看看吧
    2016-11-11
  • jquery動態(tài)加載js/css文件方法(自寫小函數(shù))

    jquery動態(tài)加載js/css文件方法(自寫小函數(shù))

    jquery自帶的getSrcript文件只能動態(tài)加載js代碼,但不能加載css,后來自己寫了一個可加載js與css的程序
    2014-10-10
  • jQuery中$(function() {});問題詳解

    jQuery中$(function() {});問題詳解

    $(function() {});是$(document).ready(function(){ })的簡寫,最早接觸的時候也說$(document).ready(function(){ })這個函數(shù)是用來取代頁面中的window.onload;但是今天發(fā)現(xiàn) 好像不是這樣回事!是在做一個頁面載入效果時發(fā)現(xiàn)的!
    2015-08-08

最新評論