美文网首页
五、Vue动画 ------ 2020-05-07

五、Vue动画 ------ 2020-05-07

作者: 自己写了自己看 | 来源:发表于2020-05-07 20:19 被阅读0次

1、常见的能触发动画的操作及添加动画的方式

1、触发动画的操作:
v-if v-show v-for 路由切换

2、添加动画的方式:
 (1) CSS添加动画:
     animation
     transition
 (2) JS添加动画:
     Vue自带的钩子函数;
     第三方动画库;

2、Vue动画的基本使用:通过添加CSS样式使用

<style>
    .box {
        width: 100px;
        height: 100px;
        background: red;
    }

    /* 进入动画 */
    /* 进入的一瞬间添加的属性 */
    .v-enter {
        background: blue;
    }

    /* v-enter-active 和 v-enter-to 会被同时添加到元素上 */
    .v-enter-active {
        transition: all 2s ease-in;
    }

    .v-enter-to {
        background: black;
    }

    /* 离开动画 */
    /* v-leave 没有实际意义,为了美感而生 */
    .v-leave {}

    .v-leave-active {
        background: yellow;
        transition: all 2s ease-in;
    }

    .v-leave-to {
        background: skyblue;
    }
</style>

<div id="app">
    <button @click="btnClick">点击</button>
    <transition name="">
        <div class="box" v-show="isShow"></div>
    </transition>
</div>

// 如果我们不想使用Vue默认的样式名我们可以通过给 transition添加 name属性修改

3、Vue动画的基本使用:通过JS添加动画

<div id="app">
    <button @click="btnClick">点击</button>
    <transition 
    @before-enter="beforeEnter" 
    @enter="enter" 
    @after-enter="afterEnter"
    @before-leave="beforeLeave"
    @leave="leave"
    @after-leave="afterLeave"
    >
        <div class="box" v-show="isShow"></div>
    </transition>
</div>

const vm = new Vue({
        el: '#app',
        data: {
            isShow: false
        },
        methods: {
            btnClick() {
                this.isShow = !this.isShow;
            },
            beforeEnter(el) {
                el.style.background = "red";
            },
            enter(el, done) {
                el.style.background = "yellow";
                setTimeout(function () {
                    done(); // 调用 done 方法 才会继续执行 afterEnter
                }, 2000)
                el.addEventListener('transitionend', done)
            },
            afterEnter(el) {
                el.style.background = "blue"
            }
        }
    })

4、结合animate.css使用Vue动画

<div id="app">
    <button @click="btnClick">点击</button>
    <transition>
        <div class="box animated" 
            v-show="isShow" 
            enter-active-class="bounceInLeft" 
            leave-active-class="bounceOutLeft">
        </div>
    </transition>
</div>

// 将动画进入和离开时的class改成第三方库的动画class
enter-active-class="bounceInLeft" 
leave-active-class="bounceOutLeft"

相关文章

  • 五、Vue动画 ------ 2020-05-07

    1、常见的能触发动画的操作及添加动画的方式 2、Vue动画的基本使用:通过添加CSS样式使用 3、Vue动画的基本...

  • Vue中的动画

    Vue动画 Vue动画API 定义不同的名称动画 第三方动画库Animate.css和Vue的结合使用 enter...

  • 前端系统学习 10. Vue高级用法

    Vue 高级用法 动画特效 transition 实现路由切换动画 App.vue Home -> List ->...

  • vue的动画特效

    一、Vue中的CSS动画原理transition标签 二、Vue中的JS动画与velocity.js 三、Vue中...

  • Vue动画

    vue动画 1. vue不能直接实现动画,只提供动画各阶段需要的class 2. 组件提供...

  • Vue神一般的打开姿势

    过渡&动画 vue 动画的理解 1)操作 css 的 trasition 或 animation2)vue 会给目...

  • Vue动画

    Vue动画 Vue动画 CSS transition 在进入/离开的过渡中,会有 6 个 class 切换。 对于...

  • Vue动画之五: 动画组件封装

    动画除了普通的是现方法, 还可以进行组件封装。下面的代码, 就是封装了一个动画组件,fade。组件的写法和普通的组...

  • 2021-01-08

    Vue过渡和动画 Vue过渡和动画官方文档[https://cn.vuejs.org/v2/guide/trans...

  • vue动画组

    vue动画组 代码块

网友评论

      本文标题:五、Vue动画 ------ 2020-05-07

      本文链接:https://www.haomeiwen.com/subject/gvezghtx.html