首頁  >  文章  >  web前端  >  jQuery animate easing使用方法圖文詳解

jQuery animate easing使用方法圖文詳解

高洛峰
高洛峰原創
2016-12-28 09:15:141337瀏覽

從jQuery API 文件中可以知道,jQuery自訂動畫的函數.animate( properties [, duration] [, easing] [, complete] )有四個參數:

• properties:一組包含作為動畫屬性和終值的樣式屬性和及其值的集合

• duration(可選):動畫執行時間,其值可以是三種預定速度之一的字串("slow", "normal", or "fast" )或表示動畫時長的毫秒數值(如:1000)

• easing(可選):要使用的過渡效果的名稱,如:"linear" 或"swing"

• complete(可選):在動畫完成時執行的函數

其中參數easing預設有兩個效果:"linear"和"swing",如果需要更多效果就要插件支援了,jQuery Easing Plugin提供了像"easeOutExpo"、"easeOutBounce"等30多種效果,大家可以點選這裡去看每一種easing的示範效果,以下詳細介紹下其使用方法及每種easing的曲線圖。

jQuery easing 使用方法

首先,專案中如果需要使用特殊的動畫效果,則需要在引入jQuery之後引入jquery.easing.1.3.js

<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.3.js"></script>
<script type="text/javascript" src="http://gsgd.co.uk/sandbox/jquery/easing/jquery.easing.1.3.js"></script>

引入之後,easing參數可選的值就有以下32種:

1. linear
2. swing
3. easeInQuad
4. easeOutQuad
5. easeInOutQuad
6. easeInCubic
7.OuteaseCubicInOutQuad
6. easeInCubic
7。
11. easeInOutQuart
12 . easeInQuint
13. easeOutQuint
14. easeInOutQuint
15. easeInExpo
16. easeOutExpo
17. easeInOutExpo
18. easeInOutine
19. easeInOutExpo
18. easeInOutine
19. easeInOutinalc. 22. easeOutCirc
23. easeInOutCirc
24. easeInElastic
25. easeOutElastic
26. easeInOutElastic
27. easeInBack
28. easeOutBack
29. easeInOutBack
30. easeInBounce
31. easeInOutBack
30. easeInBounce
31. easeInOutBack
30. easeInBounce

31. easeInBou ,為了減少程式碼冗餘,必要時可以不用引入整個jquery.easing.1.3.js,我們可以只把我們需要的幾種easing放入Javascript文件中,如專案中只用到"easeOutExpo"和"easeOutBounce"兩種效果,只需要下面的程式碼就可以了

jQuery.extend( jQuery.easing, 
{ 
easeOutExpo: function (x, t, b, c, d) { 
return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b; 
}, 
easeOutBounce: function (x, t, b, c, d) { 
if ((t/=d) < (1/2.75)) { 
return c*(7.5625*t*t) + b; 
} else if (t < (2/2.75)) { 
return c*(7.5625*(t-=(1.5/2.75))*t + .75) + b; 
} else if (t < (2.5/2.75)) { 
return c*(7.5625*(t-=(2.25/2.75))*t + .9375) + b; 
} else { 
return c*(7.5625*(t-=(2.625/2.75))*t + .984375) + b; 
} 
}, 
});

使用jQuery自訂動畫函數animate來指定easing效果,如自訂一種類彈簧效果的動畫:

$(myElement).animate({ 
top: 500, 
opacity: 1 
}, 1000, &#39;easeOutBounce&#39;);

值得一提的是jQuery 1.4版本中對animate()方法,easing的方法進行了擴展,支援為每個屬性指定easing方法,詳細請參考這裡,如:

//第一种写法
$(myElement).animate({ 
left: [500, &#39;swing&#39;], 
top: [200, &#39;easeOutBounce&#39;] 
}); 
//第二种写法
$(myElement).animate({ 
left: 500, 
top: 200 
}, { 
specialEasing: { 
left: &#39;swing&#39;, 
top: &#39;easeOutBounce&#39;
} 
});

使用jQuery內置動畫函數如slideUp()、slideDown()等來指定easing效果,以下兩種方法都可以:

$(myElement).slideUp(1000, method, callback}); 
$(myElement).slideUp({ 
duration: 1000, 
easing: method, 
complete: callback 
});

jQuery easing 圖解


以下圖解可以讓你更容易理解每​​一種easing的效果

jQuery animate easing使用方法图文详解

以上所述是小編給大家介紹的jQuery animate ea使用方法以上所述是小編給大家介紹的jQuery animate ead知識,希望對大家有幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!

更多jQuery animate easing使用方法圖文詳解相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn