成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jQuery中隊列queue()函數的實例教程
全站頭部文字 我要出現在這里
jQuery中隊列queue()函數的實例教程 659 2024-03-06   

如果當前jQuery對象匹配多個元素:獲取隊列時,只獲取第一個匹配元素上的隊列;設置隊列(替換隊列、追加函數)時,則為每個匹配元素都分別進行設置。
該函數屬于jQuery對象(實例)。如果需要移除并執行隊列中的第一個函數,請使用dequeue()函數。你也可以使用clearQueue()函數清空指定的隊列。

語法
jQuery 1.2 新增該函數。queue()函數具有如下兩種用法:

用法一:

jQueryObject.queue( [ queueName ] [, newQueue ] )

如果沒有指定任何參數或只指定了queueName參數,則表示獲取指定名稱的函數隊列。如果指定了newQueue參數,則表示使用新的隊列newQueue設置(替換)當前隊列中的所有內容。

用法二:

jQueryObject.queue( [ queueName ,] callback )

將指定的函數添加到指定的隊列(末尾)。
注意:queue()函數的所有設置操作針對當前jQuery對象所匹配的每一個元素;所有讀取操作只針對第一個匹配的元素。

參數
請根據前面語法部分所定義的參數名稱查找對應的參數。
queueName:可選/String類型指定的隊列名稱,默認為"fx"(表示jQuery中的標準動畫效果隊列)。
newQueue:可選/Array類型用于替換當前隊列內容的新隊列。
callback:Function類型指定的函數,將會追加到隊列中。該函數有一個函數參數,調用該參數可以移除并執行隊列中的第一個函數。

返回值
queue()函數的返回值是Array/jQuery類型,返回值的類型取決于當前queue()函數執行的是獲取操作還是設置操作。
如果queue()函數執行的是設置操作(替換隊列、追加函數),則返回當前jQuery對象本身;如果是獲取操作,則返回獲取到的函數隊列(數組)。
如果當前jQuery對象匹配多個元素,讀取數據時,queue()函數只以其中第一個匹配的元素為準。


實例:
1. jQuery為我們提供了queue()函數,來把你需要的某些代碼插入到某個隊列中

$('#test-change1').toggle(function(){
  $('#test-object1').hide('slow').queue(function(next){
    $('#test-object1').appendTo($('#test-goal1'));
    next();
  }).show('slow');

},function(){
  $('#test-object1').hide('slow').queue(function(next){
    $('#test-object1').appendTo($('#test-origin1'));
    next();      
  }).show('slow');
});

2. 自定義隊列

$("div").queue("custom", function(next) {
  $('div').css({'background':'red'});
  next();
});

但就這段代碼而已,待你真正添加進網頁,并且嘗試運行,會發現并非“所見即所得”,壓根就不會有任何效果。

修改后:

$("div").queue("custom", function(next) {
  $('div').css({'background':'red'});
  next();
})
.dequeue("custom"); //this is the key

一般對與dequeue()的定義是“刪除隊列中最頂部的函數,并且執行它”。我并不贊同用“刪除”這個字眼,而是傾向于“取出”,其實這個函數的功能就好像是一個數據結構中隊列的指針,待隊列中前一個函數執行完后,取下一個隊列最頂端的函數。

3. queue: false

$("#object")
.delay(1000, "fader")
.queue("fader", function(next) {
  $(this).animate({opacity: 0},
    {duration: 1000, queue: false});
  next();
})
.dequeue("fader")
.animate({top: "-=40"}, {duration: 2000})

前1000毫秒,只有控制高度的“fx”隊列執行,而后1000毫秒,控制不透明度的“fader”隊列和控制高度的“fx”并行。這里的并行就是queue:false

$('#section3a').slideUp(1000)
      .slideDown(1000)
      .animate({width: '50px'}, {duration: 1000, queue: false});

4. 獲取隊列長度
比如用隊列名取得匹配元素的長度:

var $queue=$("div").queue('fx');

很明顯,就是取得隊列名為'fx'的隊列,如果想取得長度的話:

var $length=$('div').queue('fx').length;

注意這里的隊列長度只是匹配元素還未運行的隊列長度,當動畫運行完之后,隊列長度會自動歸為0

5.替換隊列

$('div').queue('fx',function(){
    $('div').slideDown('slow')
         .slideUp('slow')
         .animate({left:'+=100'},4000);
});//定義fx
$('div').queue('fx2',function(){
    $('div').slideDown('fast')
         .slideUp('fast')
         .animate({left:'+=100'},1000);
});//定義fx2

這里定義了兩個隊列,一個是慢隊列,也就是默認的'fx',另一個是快隊列'fx2'

當點擊某個按鈕時:

$('input').click(function(){
  $('div').queue('fx',fx2);
});


主站蜘蛛池模板: 刑事侦缉档案1演员表| 法瑞尔·威廉姆斯| 张国强个人简历| 电影电车| 夏和平| 贾冰又出新的喜剧电影| 许忠| 湖北影视| 烽火硝烟里的青春演员表| 菊花开| 蜡笔小新日文| 托比·瑞格波| 从此以后歌词| 王盼盼| 姬诚| 白宝山电视剧26集免费观看| 豪血寺一族2出招表| 李莉莉| 腾格尔演的喜剧电影| 接吻教学视频| 糖老爹| 吉吉映画| 老爸回家 电视剧| 游吟诗人| 新生儿满月长几斤正常| 耀眼电视剧演员表| 美少女战士变身| 小涛讲电影| chinese国产xxx实拍| 尸家重地演员表| 日本电影怪物| 洛兵| 曹查理电影大全免费观看国语| 韩国电影诱惑| 寡妇年| 我爱你再见演员表| jamie dornan| 搜狐视频官网| 赏金猎人日本电影完整版| 迷斯拉| 爱奴 电影|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103