jQeury淡入淡出需要注意的問題
眾所周知,jQuery所產(chǎn)生的動(dòng)畫效果默認(rèn)會(huì)進(jìn)入列隊(duì)的。假如:點(diǎn)擊一下,產(chǎn)生動(dòng)畫3秒鐘。然后我快速的連點(diǎn)3次。那么要等到9秒鐘,所有動(dòng)畫才能結(jié)束。animate是自定義動(dòng)畫,可以很容易的設(shè)定動(dòng)畫是否進(jìn)入列隊(duì)。但使用fadeIn和fadeOut就麻煩了。
看到有的Flash網(wǎng)站的圖標(biāo),鼠標(biāo)一放上去圖標(biāo)就緩緩變了,移開又會(huì)緩緩變回來,很是漂亮。我打算用jQuery也做做看,能不能做出類似的效果。因?yàn)樽约壕毷?,就隨便拉兩張圖片:
<div id="div">
<img id="1" src="florian.jpg" style= "position:absolute;z-index:2;left:10px;top:10px;"/>
<img id="2" src="kamil.jpg" style= "position:absolute;z-index:1;left:10px;top:10px;"/>
</div>
這樣第一張就會(huì)覆蓋第二張圖片,那我只要淡入淡出第一張圖片就能實(shí)現(xiàn)特效了。于是就使用了hover,fadeIn和fadeOut,簡單的實(shí)現(xiàn)了
$(document).ready(function () {
$("div").hover(
function () { $("#1").fadeOut(1000); },
function () { $("#1").fadeIn(1000); }
);
});
但這樣問題出來了,如果我在圖片上不停地快速的移入移出鼠標(biāo)。那么動(dòng)畫都進(jìn)入列隊(duì)了,那么動(dòng)畫就會(huì)一直在動(dòng),很是不好看。
于是我打算使用:dequeue(),定義:Removes a queued function from the front of the queue and executes it.
我想如果不停的移入移出,那么就會(huì)刪除上一個(gè)操作在列隊(duì)中的動(dòng)畫。這樣就會(huì)執(zhí)行最后的動(dòng)畫了。
function () { $("#1").dequeue().fadeOut(1000); },
function () { $("#1").dequeue().fadeIn(1000); }
可是更麻煩的情況出現(xiàn)了,當(dāng)不停地移入移出鼠標(biāo)時(shí),有時(shí)圖片都沒了,有時(shí)不變了。怎么回事?
然后又想到使用:stop(),定義:
Stops all the currently running animations on all the specified elements.
If any animations are queued to run, then they will begin immediately.
function () { $("#1").stop().fadeOut(1000); },
function () { $("#1").stop().fadeIn(1000); }
我停止前面所有的列隊(duì),總算可以了吧!但是卻出現(xiàn)了圖片淡到一半,不動(dòng)了!就像兩個(gè)圖片疊加顯示了一樣。
又是怎么回事?
直到我在stop中加參數(shù),圖片才能正常顯示。
clearqueue (可選)boolean
如果設(shè)置成true,則清空隊(duì)列。可以立即結(jié)束動(dòng)畫。
gotoend (可選)boolean
讓當(dāng)前正在執(zhí)行的動(dòng)畫立即完成,并且重設(shè)show和hide的原始樣式,調(diào)用回調(diào)函數(shù)等。
function () { $("#1").stop(true,true).fadeOut(1000); },
function () { $("#1").stop(true, true).fadeIn(1000); }
但這樣就會(huì)出現(xiàn)執(zhí)行完畢,突然顯示整圖的情況,就沒有了淡入淡出的那樣的效果了。
沒辦法,只有使用animate了。
function () { $("#1").stop().animate({ 'opacity': 0 }, 1000); },
function () { $("#1").stop().animate({'opacity':1}, 1000); }
或:
function () { $("#1").animate({ 'opacity': 0 }, { queue: false, duration: 1000 }); },
function () { $("#1").animate({ 'opacity': 1 }, { queue: false, duration: 1000 }); }
這才實(shí)現(xiàn)了想要的完美效果。
總結(jié)一下,使用stop和dequeue理論都是可以的,但為什么卻出錯(cuò)?我也不太清楚,估計(jì)是jQuery庫的問題吧,
這個(gè)要查原文件才找得到問題。但以后使用fadeIn和fadeOut真的注意一下。當(dāng)然,到橡樹小屋朋友的
《JQuery實(shí)現(xiàn)圖片輪播效果》肯定是個(gè)好例子,直到我把時(shí)間改到2000才看出來有延遲的。只有我故意找毛病的人才會(huì)
這么干,其他哪還有人會(huì)設(shè)這么長的時(shí)間的。有興趣的朋友可以去橡樹小屋那學(xué)習(xí)一下,既簡單又漂亮實(shí)用的例子。
- jQuery 淡入淡出、展開收縮菜單實(shí)現(xiàn)代碼
- 一步一步教你寫淡入淡出帶注釋的圖片輪播插件(一)
- 基于Jquery的淡入淡出的特效基礎(chǔ)練習(xí)
- js運(yùn)動(dòng)框架_包括圖片的淡入淡出效果
- js控制淡入淡出示例代碼
- 原生js實(shí)現(xiàn)fadein 和 fadeout淡入淡出效果
- JS實(shí)現(xiàn)文字鏈接感應(yīng)鼠標(biāo)淡入淡出改變顏色的方法
- 原生js和jquery實(shí)現(xiàn)圖片輪播淡入淡出效果
- js淡入淡出的圖片輪播效果代碼分享
- js淡入淡出焦點(diǎn)圖幻燈片效果代碼分享
- js如何實(shí)現(xiàn)淡入淡出效果
相關(guān)文章
jQuery實(shí)現(xiàn)側(cè)邊導(dǎo)航欄及滑動(dòng)電梯效果(仿淘寶)
這篇文章主要介紹了如何利用JQuery+CSS模擬淘寶實(shí)現(xiàn)側(cè)邊導(dǎo)航欄以及滑動(dòng)電梯效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手試一試2022-03-03jquery mobile的觸控點(diǎn)擊事件會(huì)多次觸發(fā)問題的解決方法
這篇文章主要介紹了jquery mobile的觸控點(diǎn)擊事件會(huì)多次觸發(fā)問題的解決方法以及替代方法,需要的朋友可以參考下2014-05-05dul無法加載bootstrap實(shí)現(xiàn)unload table/user恢復(fù)
這篇文章主要介紹了dul無法加載bootstrap實(shí)現(xiàn)unload table/user恢復(fù)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09jQuery實(shí)現(xiàn)動(dòng)態(tài)刪除LI的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)刪除LI的方法,結(jié)合實(shí)例形式分析了jQuery針對頁面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-05-05利用jQuery及AJAX技術(shù)定時(shí)更新GridView的某一列數(shù)據(jù)
這篇文章主要介紹了利用jQuery及AJAX技術(shù)定時(shí)更新GridView的某一列數(shù)據(jù)的方法,這里的GridView是指C#軟件開發(fā)中的GridView控件,需要的朋友可以參考下2015-12-12jq stop()和:is(:animated)的用法及區(qū)別(詳解)
下面小編就為大家?guī)硪黄猨q stop()和:is(:animated)的用法及區(qū)別(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02基于jquery的禁用右鍵、文本選擇功能、復(fù)制按鍵的實(shí)現(xiàn)代碼
有時(shí)候因?yàn)槟承┰?,需要禁止用戶的右鍵、文本選擇功能、復(fù)制按鍵等操作,那么就可以參考下面的代碼2013-08-08