使用veloticy-ui生成文字動(dòng)畫(huà)效果
前言
最近要實(shí)現(xiàn)一個(gè)類似文字波浪線的效果,使用了velocity-ui這個(gè)動(dòng)畫(huà)庫(kù),第一個(gè)感覺(jué)就是使用簡(jiǎn)單,代碼量少,性能優(yōu)異,在此簡(jiǎn)單介紹一下使用方法,并實(shí)現(xiàn)一個(gè)看上去不錯(cuò)的動(dòng)畫(huà).
基本使用
要使用 velocity-ui 需要先引入velocity,其中velocity可以是依賴jquery,也可以不依賴jquery,具體看一下下面就行了
//不依賴jquery,第一個(gè)參數(shù)為原生js的dom選擇器
Velocity(document.getElementById("dummy"), {
opacity: 0.5
}, {
duration: 1000
});
// 使用 jQuery 或 Zepto 時(shí)
$("#dummy").velocity({
opacity: 0.5
}, {
duration: 1000
});
可以看出在使用jquery時(shí),velocity的基本使用就像jquery的animate,引入 velocity-ui 的
目的就是提供一些已經(jīng)定義好的動(dòng)畫(huà)(指令),有一點(diǎn)像Animate.css這樣的動(dòng)畫(huà)庫(kù),但是可以提供
更細(xì)致的控制,
基本配置項(xiàng)
$element.velocity({
width: "500px", // 動(dòng)畫(huà)屬性 寬度到 "500px" 的動(dòng)畫(huà)
property2: value2 // 屬性示例
}, {
/* Velocity 動(dòng)畫(huà)配置項(xiàng)的默認(rèn)值 */
duration: 400, // 動(dòng)畫(huà)執(zhí)行時(shí)間
easing: "swing", // 緩動(dòng)效果
queue: "", // 隊(duì)列
begin: undefined, // 動(dòng)畫(huà)開(kāi)始時(shí)的回調(diào)函數(shù)
progress: undefined, // 動(dòng)畫(huà)執(zhí)行中的回調(diào)函數(shù)(該函數(shù)會(huì)隨著動(dòng)畫(huà)執(zhí)行被不斷觸發(fā))
complete: undefined, // 動(dòng)畫(huà)結(jié)束時(shí)的回調(diào)函數(shù)
display: undefined, // 動(dòng)畫(huà)結(jié)束時(shí)設(shè)置元素的 css display 屬性
visibility: undefined, // 動(dòng)畫(huà)結(jié)束時(shí)設(shè)置元素的 css visibility 屬性
loop: false, // 循環(huán)
delay: false, // 延遲
mobileHA: true // 移動(dòng)端硬件加速(默認(rèn)開(kāi)啟)
});
width: ["500px", "300px"]//這樣設(shè)置后面的300px會(huì)作為初始默認(rèn)值
width: ["500px", "spring","300px"]//這樣可以為單個(gè)屬性指定緩動(dòng)函數(shù)
width: function (index, total) {}//對(duì)集合對(duì)象可以設(shè)置不同的屬性值
可以看出velocity也可以設(shè)置quequ,使用和animate是一致的,而且velocity自身提供一些指令來(lái)實(shí)現(xiàn)動(dòng)畫(huà),有fadeIn/fadeOut, slideUp/slideDown,
scroll,finish,reverse,除此以外velocity實(shí)現(xiàn)了對(duì)transform, color這些屬性動(dòng)畫(huà)的支持,并支持SVG和promise,具體使用可以看上面鏈接的文檔。
velocity-ui 除了提供更多的指令外,還提供了兩個(gè)方法 RunSequence 和 RegisterEffect(非jquery可以去掉$.,把jquery換為原生DOM)
// 將嵌套動(dòng)畫(huà)序列儲(chǔ)存到一個(gè)數(shù)組里,很清晰的顯示了它們的執(zhí)行順序
var mySequence = [
{ e: $element1, p: { translateX: 100 }, o: { duration: 1000 } },
{ e: $element2, p: { translateX: 200 }, o: { duration: 1000 } },
{ e: $element3, p: { translateX: 300 }, o: { duration: 1000 } }
];
// 調(diào)用這個(gè)自定義的序列名稱 還可以在其他地方復(fù)用
$.Velocity.RunSequence(mySequence);
// name:動(dòng)畫(huà)特效名稱 為字符串類型
// defaultDuration:默認(rèn)動(dòng)畫(huà)執(zhí)行時(shí)間 單位為毫秒(ms)
// calls:動(dòng)畫(huà)隊(duì)列數(shù)組,property - 動(dòng)畫(huà)屬性,durationPercentage - 當(dāng)前動(dòng)畫(huà)所占總時(shí)間的百分比 (寫(xiě)成浮點(diǎn)數(shù)),option - 選項(xiàng)
// reset:設(shè)置元素在動(dòng)畫(huà)開(kāi)始時(shí)的初始值
$.Velocity.RegisterEffect(name, {
defaultDuration: duration,
calls: [
[ { property: value }, durationPercentage, { options } ],
[ { property: value }, durationPercentage, { options } ]
],
reset: { property: value, property: value }
});
除了以上兩個(gè)函數(shù)外,還提供了3個(gè)額外的options屬性
stagger 可以讓集合對(duì)象依次錯(cuò)開(kāi)一段時(shí)間執(zhí)行動(dòng)畫(huà)
drag 可以讓集合對(duì)象的最后一個(gè)元素有緩沖效果
backwards 可以讓集合對(duì)象從最后一個(gè)元素往前依次錯(cuò)開(kāi)一段時(shí)間執(zhí)行動(dòng)畫(huà)
下面就利用 RegisterEffect 和 stagger 實(shí)現(xiàn)一個(gè)簡(jiǎn)單的文字動(dòng)畫(huà)
實(shí)現(xiàn)一個(gè)自定義動(dòng)畫(huà)
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<meta name="renderer" content="webkit">
<title>Document</title>
</head>
<body>
<h1 id="J_Text">segmentfault</h1>
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/velocity/1.5.1/velocity.min.js"></script>
<script src="https://cdn.bootcss.com/velocity/1.5.1/velocity.ui.min.js"></script>
<script>
jQuery(function ($) {
$.Velocity.RegisterEffect('custom', {//注冊(cè)一個(gè)叫'custom'自定義動(dòng)畫(huà)
defaultDuration: 1500,
calls:[
[{
rotateY: 360,
translateY: '-=15',
}, 0.5],
[{
translateY: '+=15',
}, 0.5]
],
})
$('#J_Text').css({
fontSize: 40,
color: '#333',
}) .html(function () {
return $(this).text().split('').map(function (char) {
return '<span>' + char + '</span>'; //讓每字符被span元素包裹
}).join('');
}).find('span')
.filter(function (index) {
return index > 6
}).css('color', '#009A63').end() //讓后面幾個(gè)字符變?yōu)榫G色
.css({
position: 'absolute',
left: function (index) {
return index * 20; //設(shè)置字符的間隔
}
})
.velocity('custom', { //調(diào)用自定義的動(dòng)畫(huà)指令
stagger: 300,
delay: 1000,
})
})
</script>
</body>
</html>

除去一些字符的操作,可以看出實(shí)現(xiàn)一個(gè)看似復(fù)雜的動(dòng)畫(huà)只需簡(jiǎn)單設(shè)置calls 和stagger屬性的值就可以了,這個(gè)gif在循環(huán)播放那個(gè)動(dòng)畫(huà),實(shí)際上這個(gè)動(dòng)畫(huà)只執(zhí)行了一次,大家可以思考一下怎么實(shí)現(xiàn)整個(gè)隊(duì)列的循環(huán)
最后
velocity內(nèi)部由于對(duì)動(dòng)畫(huà)方面進(jìn)行了優(yōu)化,所以性能方面比jquery的animate要好,甚至比css的transition還要出色,當(dāng)然這個(gè)我沒(méi)有測(cè)試過(guò),大家可以測(cè)試一下。
總結(jié)
以上所述是小編給大家介紹的使用veloticy-ui生成文字動(dòng)畫(huà)效果,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
基于JQuery的asp.net樹(shù)實(shí)現(xiàn)代碼
在網(wǎng)上找了tree,想直接拿來(lái)用,誰(shuí)知道竟然沒(méi)有找到基于asp.net的tree,索性自己便把jquery的tree拿來(lái)研究了下,然后結(jié)合者asp.net,做了一個(gè)遞歸樹(shù).2010-11-11
基于EasyUI的基礎(chǔ)之上實(shí)現(xiàn)樹(shù)形功能菜單
這篇文章主要介紹了基于EasyUI的基礎(chǔ)之上實(shí)現(xiàn)樹(shù)形功能菜單,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-06-06
jQuery實(shí)現(xiàn)的粘性滾動(dòng)導(dǎo)航欄效果實(shí)例【附源碼下載】
這篇文章主要介紹了jQuery實(shí)現(xiàn)的粘性滾動(dòng)導(dǎo)航欄效果,涉及jQuery插件smint的相關(guān)使用技巧,并附帶完整實(shí)例源碼供讀者下載參考,需要的朋友可以參考下2017-10-10
jQuery插件jquery-barcode實(shí)現(xiàn)條碼打印的方法
這篇文章主要介紹了jQuery插件jquery-barcode實(shí)現(xiàn)條碼打印的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了jQuery插件jquery-barcode的功能及打印條碼的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
使用jQuery的toggle()方法對(duì)HTML標(biāo)簽進(jìn)行顯示、隱藏的方法(示例)
本文通過(guò)示例給大家介紹了使用jQuery的toggle()方法對(duì)HTML標(biāo)簽進(jìn)行顯示、隱藏操作的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
基于jquery實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)效果
這篇文章主要介紹了基于jquery實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)效果,需要的朋友可以參考下2015-12-12
jQuery設(shè)置聚焦并使光標(biāo)位置在文字最后的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇jQuery設(shè)置聚焦并使光標(biāo)位置在文字最后的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08

