亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用veloticy-ui生成文字動畫效果

 更新時間:2018年02月08日 11:13:00   作者:changli  
這篇文章主要介紹了使用veloticy-ui生成文字動畫效果及基本使用方法,需要的朋友可以參考下

前言

最近要實現(xiàn)一個類似文字波浪線的效果,使用了velocity-ui這個動畫庫,第一個感覺就是使用簡單,代碼量少,性能優(yōu)異,在此簡單介紹一下使用方法,并實現(xiàn)一個看上去不錯的動畫.

具體使用方法可以點擊這里

基本使用

要使用 velocity-ui 需要先引入velocity,其中velocity可以是依賴jquery,也可以不依賴jquery,具體看一下下面就行了

//不依賴jquery,第一個參數(shù)為原生js的dom選擇器
Velocity(document.getElementById("dummy"), {
 opacity: 0.5
}, {
 duration: 1000
});
// 使用 jQuery 或 Zepto 時
$("#dummy").velocity({
 opacity: 0.5
}, {
 duration: 1000
});

可以看出在使用jquery時,velocity的基本使用就像jquery的animate,引入 velocity-ui 的

目的就是提供一些已經定義好的動畫(指令),有一點像Animate.css這樣的動畫庫,但是可以提供

更細致的控制,

基本配置項

$element.velocity({
 width: "500px", // 動畫屬性 寬度到 "500px" 的動畫
 property2: value2 // 屬性示例
}, {
 /* Velocity 動畫配置項的默認值 */
 duration: 400,  // 動畫執(zhí)行時間
 easing: "swing", // 緩動效果
 queue: "",  // 隊列
 begin: undefined, // 動畫開始時的回調函數(shù)
 progress: undefined, // 動畫執(zhí)行中的回調函數(shù)(該函數(shù)會隨著動畫執(zhí)行被不斷觸發(fā))
 complete: undefined, // 動畫結束時的回調函數(shù)
 display: undefined, // 動畫結束時設置元素的 css display 屬性
 visibility: undefined, // 動畫結束時設置元素的 css visibility 屬性
 loop: false,  // 循環(huán)
 delay: false,  // 延遲
 mobileHA: true  // 移動端硬件加速(默認開啟)
});
width: ["500px", "300px"]//這樣設置后面的300px會作為初始默認值
width: ["500px", "spring","300px"]//這樣可以為單個屬性指定緩動函數(shù)
width: function (index, total) {}//對集合對象可以設置不同的屬性值

可以看出velocity也可以設置quequ,使用和animate是一致的,而且velocity自身提供一些指令來實現(xiàn)動畫,有fadeIn/fadeOut, slideUp/slideDown,

scroll,finish,reverse,除此以外velocity實現(xiàn)了對transform, color這些屬性動畫的支持,并支持SVG和promise,具體使用可以看上面鏈接的文檔。

velocity-ui 除了提供更多的指令外,還提供了兩個方法 RunSequence 和 RegisterEffect(非jquery可以去掉$.,把jquery換為原生DOM)

// 將嵌套動畫序列儲存到一個數(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 } }
];
// 調用這個自定義的序列名稱 還可以在其他地方復用
$.Velocity.RunSequence(mySequence);
// name:動畫特效名稱 為字符串類型
// defaultDuration:默認動畫執(zhí)行時間 單位為毫秒(ms)
// calls:動畫隊列數(shù)組,property - 動畫屬性,durationPercentage - 當前動畫所占總時間的百分比 (寫成浮點數(shù)),option - 選項
// reset:設置元素在動畫開始時的初始值
$.Velocity.RegisterEffect(name, {
 defaultDuration: duration,
 calls: [
 [ { property: value }, durationPercentage, { options } ],
 [ { property: value }, durationPercentage, { options } ]
 ],
 reset: { property: value, property: value }
});

除了以上兩個函數(shù)外,還提供了3個額外的options屬性

stagger 可以讓集合對象依次錯開一段時間執(zhí)行動畫

drag 可以讓集合對象的最后一個元素有緩沖效果

backwards 可以讓集合對象從最后一個元素往前依次錯開一段時間執(zhí)行動畫

下面就利用 RegisterEffect 和 stagger 實現(xiàn)一個簡單的文字動畫

實現(xiàn)一個自定義動畫 

<!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', {//注冊一個叫'custom'自定義動畫
 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() //讓后面幾個字符變?yōu)榫G色
 .css({
 position: 'absolute',
 left: function (index) {
  return index * 20; //設置字符的間隔
 }
 })
 .velocity('custom', { //調用自定義的動畫指令
 stagger: 300,
 delay: 1000, 
 })
 })
 </script>
</body>
</html>

除去一些字符的操作,可以看出實現(xiàn)一個看似復雜的動畫只需簡單設置calls 和stagger屬性的值就可以了,這個gif在循環(huán)播放那個動畫,實際上這個動畫只執(zhí)行了一次,大家可以思考一下怎么實現(xiàn)整個隊列的循環(huán)

最后

velocity內部由于對動畫方面進行了優(yōu)化,所以性能方面比jquery的animate要好,甚至比css的transition還要出色,當然這個我沒有測試過,大家可以測試一下。

總結

以上所述是小編給大家介紹的使用veloticy-ui生成文字動畫效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • jquery實現(xiàn)表格行拖動排序

    jquery實現(xiàn)表格行拖動排序

    這篇文章主要為大家詳細介紹了jquery實現(xiàn)表格行拖動排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • JQuery1.6 使用方法三

    JQuery1.6 使用方法三

    JQuery1.6 使用方法三,想要學習jquery的朋友可以參考下。
    2011-11-11
  • jQuery實現(xiàn)信息提示框(帶有圓角框與動畫)效果

    jQuery實現(xiàn)信息提示框(帶有圓角框與動畫)效果

    這篇文章主要介紹了jQuery實現(xiàn)信息提示框效果,帶有圓角框與動畫功能,點擊上面按鈕實現(xiàn)對應文字的漸變顯示效果,非常具有實用價值,需要的朋友可以參考下
    2015-08-08
  • jQuery中trigger()與bind()用法分析

    jQuery中trigger()與bind()用法分析

    這篇文章主要介紹了jQuery中trigger()與bind()用法,結合實例形式分析了trigger()與bind()的功能、定義及具體使用技巧,需要的朋友可以參考下
    2015-12-12
  • getJSON調用后臺json數(shù)據(jù)時函數(shù)被調用兩次的原因猜想

    getJSON調用后臺json數(shù)據(jù)時函數(shù)被調用兩次的原因猜想

    近期在做前端開發(fā)時候使用到getJSON調用后臺json數(shù)據(jù),發(fā)現(xiàn)后臺的函數(shù)被調用兩次,函數(shù)名稱為getMessages,下面是本人的一些猜想,感興趣的朋友可以參考下
    2013-09-09
  • 整理的40個有用的jQuery技術和教程

    整理的40個有用的jQuery技術和教程

    jQuery確實是一項偉大的技術,通過jQuery的插件,我們可以方便的創(chuàng)建具有更好用戶界面的網站。在本文中,將和大家分享40個對你創(chuàng)建更好用戶界面的jQuery技術和教程。
    2011-01-01
  • jquery操作HTML5 的data-*的用法實例分享

    jquery操作HTML5 的data-*的用法實例分享

    從jQuery 1.4.3起, HTML 5 data- 屬性 將自動被引用到jQuery的數(shù)據(jù)對象中。也就是說雖然 data-* 是在html5 中的元素, 但是如果使用 jquery 1.4.3庫以上的.還是可以 在非HTML5的頁面或瀏覽器里, 仍然可以使用.data(obj)方法來操作"data-*" 數(shù)據(jù).
    2014-08-08
  • jQuery中 noConflict() 方法使用

    jQuery中 noConflict() 方法使用

    如何在頁面上同時使用 jQuery 和其他框架?
    2013-04-04
  • bootstrap table sum總數(shù)量統(tǒng)計實現(xiàn)方法

    bootstrap table sum總數(shù)量統(tǒng)計實現(xiàn)方法

    這篇文章主要介紹了bootstrap table sum總數(shù)量統(tǒng)計實現(xiàn)方法,需要的朋友可以參考下
    2017-10-10
  • jQuery實現(xiàn)簡單的圖片查看器

    jQuery實現(xiàn)簡單的圖片查看器

    這篇文章主要介紹了jQuery實現(xiàn)簡單的圖片查看器的相關資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-12-12

最新評論