Vue中的 Js 動畫與 Velocity.js 的結合

當只用 JavaScript 過渡的時候,在 enter 和 leave 中必須使用 done 進行回調。否則,它們將被同步調用,過渡會立即完成。

推薦對於僅使用 JavaScript 過渡的元素添加 v-bind:css="false",Vue 會跳過 CSS 的檢測。這也可以避免過渡過程中 CSS 的影響。

一個js動畫的簡單 例子:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Vue 動畫</title>
    <script src="./vue.js"></script>
    <link href="https://cdn.jsdelivr.net/npm/[email protected]" rel="stylesheet" type="text/css">
    <!--Velocity 和 jQuery.animate 的工作方式類似,也是用來實現 JavaScript 動畫的一個很棒的選擇-->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>

    <style>

    </style>
</head>

<body>

    <div id="root">
        <transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
            <h1 v-show="show">Hello World</h1>
        </transition>
        <button @click="handleClick">toggle</button>
    </div>

    <script>
        var app = new Vue({
            el: " #root ",
            data: {
                show: true

            },
            methods: {
                handleClick: function() {
                    this.show = !this.show;
                },
                handleBeforeEnter: function(el) { //el指動畫包裹的div標籤
                    console.log('beforeEnter');
                    el.style.color = 'red';
                },
                handlerEnter: function(el, done) { //done是回調函數 
                    setTimeout(() => { //2s green
                        el.style.color = "green"
                    }, 2000)
                    setTimeout(() => { //再2s後 black
                        el.style.color = "black"
                    }, 4000)
                },
                handleAfterEnter: function(el) {
                    el.style.color = "#000"
                },
            }
        })
    </script>
</body>

</html>

幾個鉤子名稱:

before-enter,enter,after-enter,before-leave,leave,after-leave

一使用 Velocity.js 的簡單例子:

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Vue 動畫</title>
    <script src="./vue.js"></script>
    <link href="https://cdn.jsdelivr.net/npm/[email protected]" rel="stylesheet" type="text/css">
    <!--Velocity 和 jQuery.animate 的工作方式類似,也是用來實現 JavaScript 動畫的一個很棒的選擇-->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>

    <style>

    </style>
</head>

<body>

    <div id="root">
        <transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
            <h1 v-show="show">Hello World</h1>
        </transition>
        <button @click="handleClick">toggle</button>
    </div>

    <script>
        var app = new Vue({
            el: " #root ",
            data: {
                show: true

            },
            methods: {
                handleClick: function() {
                    this.show = !this.show;
                },
                handleBeforeEnter: function(el) { //el指動畫包裹的div標籤
                    el.style.opacity = 0;
                },
                handlerEnter: function(el, done) { //done是回調函數 
                    Velocity(el, {
                        opacity: 1
                    }, { //complete:done 當執行動畫之後,done回調會被執行
                        duration: 1000,
                        complete: done
                    })
                },
                handleAfterEnter: function(el) {
                    alert("動畫結束")
                },
            }
        })
    </script>
</body>

</html>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章