最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • ⒔ Vue的过渡 & 动画

    正文概述 掘金(CRMEB技术团队)   2021-01-14   474

    在 Vue.js 中,所有动画的具体实现主要是通过组件 <transition><transition-group> 来实现的。

    两者的主要区别是:

    1. <transition> 针对单个元素进行动画渲染(多个元素需要使用一个父元素包裹)
    2. <transition-group> 针对列表元素进行动画渲染

    除此之外两者并没有本质上的区别!

    <transition> 组件

    在vuejs中触发动画的条件主要有4个:

    1. 条件渲染(使用v-if)
    2. 条件展示(使用v-show)
    3. 动态组件
    4. 组件跟节点

    满足上面的4个条件都会触发动画!

    老规矩,翠花上代码:

     	<style>
            #app {
                text-align: center
            }
            p {
                width: 350px;
                height: 150px;
                line-height: 150px;
                text-align: center;
                background-color: bisque;
                margin: 16px auto;
            }
            /* anim-1动画样式 */
            .anim-1-enter {
                transform: translateX(100px);
                opacity: 0;
            }
        
            .anim-1-enter-active {
                transition: all 1s ease;
            }
        
            .anim-1-leave-to {
                transform: translateX(-100px);
                opacity: 0;
            }
        
            .anim-1-leave-active {
                transition: all 1s ease;
            }
        	/* anim-2动画样式 */
            .anim-2-enter-active {
                animation: bounce-in 1s;
            }
            .anim-2-leave-active {
                animation: bounce-in 1s reverse;
            }
            @keyframes bounce-in {
                0% {
                    transform: scale(0);
                }
                50% {
                    transform: scale(1.5);
                }
                100% {
                    transform: scale(1);
                }
            }
        </style>
        
        <div id="app">
            <div>
                <button @click="show = !show">toggin</button>
            </div>
            <transition name="anim-1" >
                <p v-if="show">v-if 动画一</p>
            </transition>
            <transition name="anim-2">
                <p v-show="show">v-show 动画二</p>
            </transition>
        </div>
        
        <script>
        
            var vm = new Vue({
                el: '#app',
                data: {
                    show: true,
                },
            });
        </script>
    

    大家可以先把上边的代码运行一遍看看效果!

    ⒔ Vue的过渡 & 动画

    就这样就简单实现一个炫酷的动画,当然css动画部分就需要大家去自行去理解意思了!

    我们来分析一下#app中定义的两个动画模块,即:

    <transition name="anim-1" >
    	<p v-if="show">v-if 动画一</p>
    </transition>
    

    开篇我们说了<transition>是vue提供给我们的动画组件,也就是说用这个组件包裹起来的部分如果有条件满足即可触发css定义的动画,那他是怎么识别到我们css中定义的动画的呢?这就就要说一下<transition>组件的name属性,这个name属性是用来定义动画过渡类的类名,默认有6个类名

    1. v-enter:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。
    2. v-enter-active:定义进入过渡生效时的状态。在整个进入过渡的阶段中应用,在元素被插入之前生效,在过渡/动画完成之后移除。这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。
    3. v-enter-to:2.1.8 版及以上定义进入过渡的结束状态。在元素被插入之后下一帧生效 (与此同时 v-enter 被移除),在过渡/动画完成之后移除。
    4. v-leave:定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。
    5. v-leave-active:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。
    6. v-leave-to:2.1.8 版及以上定义离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时 v-leave 被删除),在过渡/动画完成之后移除。

    ⒔ Vue的过渡 & 动画

    如果你使用一个没有名字的 <transition>组件,也就是没有给<transition>组件设置name(如:name="anim-1")属性,则vue提供的以上6个 v-开头的类名就是我们在css中要定义的动画类名称,如果你使用了 <transition name="my-transition">,那么默认的6个名称会分别会将v-替换为我们定义的name名称,例如: v-enter 会替换为 my-transition-enter

    答案肯定是有的,Vue允许我们自定义过渡类名!

    自定义过渡类名

    自定义过渡类名vue的<transition>组件为我们提供了6个属性,分别对应以上6个过渡类!

    1. enter-class 对应 v-enter
    2. enter-active-class 对应 v-enter-activ
    3. enter-to-class (2.1.8+)对应 v-enter-to
    4. leave-class 对应 v-leave
    5. leave-active-class 对应 v-leave-active
    6. leave-to-class (2.1.8+) 对应 v-leave-to

    他们的优先级高于普通的类名,这对于 Vue 的过渡系统和其他第三方 CSS 动画库,如 Animate.css 结合使用十分有用,这就解决了以上问题。

    翠花上代码:

    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css">
    
       <div id="example-3">
          <button @click="show = !show">
            Toggle render
          </button>
          <transition
            name="custom-classes-transition"
            enter-active-class="animated tada"
            leave-active-class="animated bounceOutRight"
          >
            <p v-if="show">hello</p>
          </transition>
        </div>
        
        <script type="text/javascript">
          new Vue({
            el: '#example-3',
            data: {
              show: true
            }
          })
        </script>
    

    ⒔ Vue的过渡 & 动画

       <transition
            name="custom-classes-transition"
            enter-active-class="animated tada"
            leave-active-class="animated bounceOutRight">
            <p v-if="show">hello</p>
       </transition>
    

    看以上代码,我相信你能看懂,这就是如何自定义过渡类的方法!

    JavaScript钩子

      // 准备进入(动画还未开始执行)
      v-on:before-enter="beforeEnter" 
      // 进入动画开始执行
      v-on:enter="enter"
      // 进入动画执行结束
      v-on:after-enter="afterEnter"
      // 进入动画被取消
      v-on:enter-cancelled="enterCancelled"
      
      // 准备离开(动画还未开始执行)
      v-on:before-leave="beforeLeave"
      // 离开动画开始执行
      v-on:leave="leave"
      // 离开动画执行结束
      v-on:after-leave="afterLeave"
      // 离开动画被取消(只在v-show下生效)
      v-on:leave-cancelled="leaveCancelled"
    

    翠花,上官方代码:

    <script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
    
    <div id="app">
        <div>
            <button @click="onStartAnim">toggin</button>
        </div>
        <transition 
            v-on:before-enter="beforeEnter"
            v-on:enter="enter"
            v-on:after-enter="afterEnter"
            v-on:enter-cancelled="enterCancelled"
    
            v-on:before-leave="beforeLeave"
            v-on:leave="leave"
            v-on:after-leave="afterLeave"
            v-on:leave-cancelled="leaveCancelled">
            <p v-show="show">v-show 动画二</p>
        </transition>
    
    </div>
    
    
    <script>
    
        var vm = new Vue({
            el: '#app',
            data: {
                show: false
            },
            methods: {
                onStartAnim: function () {
                    this.show = !this.show;
                },
                beforeEnter: function (el) {
                    // 准备进入(动画还未开始执行)
                    console.log('beforeEnter');
    
                    /**
                    * 推荐对于仅使用 JavaScript 过渡的元素添加 v-bind:css="false",Vue 会跳过 CSS 的检测。这也可以避免过渡过程中 CSS 的影响。
                    * */
                    el.style.opacity = 0
                    el.style.transformOrigin = 'left'
                },
                enter: function (el, done) {
                    // 进入动画开始执行
                    console.log('enter');
    
                    /**
                    * 当只用 JavaScript 过渡的时候,在 enter 和 leave 中必须使用 done 进行回调。否则,它们将被同步调用,过渡会立即完成。
                    * */
                    Velocity(el, { opacity: 1, fontSize: '1.4em' }, { duration: 300 })
                    Velocity(el, { fontSize: '1em' }, { complete: done })
                },
                afterEnter: function (el) {
                    // 进入动画执行结束
                    console.log('afterEnter');
                },
                enterCancelled: function (el) {
                    // 进入动画被取消
                    console.log('enterCancelled');
                },
                beforeLeave: function (el) {
                    // 准备离开(动画还未开始执行)
                    console.log('beforeLeave');
                },
                leave: function (el, done) {
                    // 离开动画开始执行
                    console.log('leave');
    
                    /**
                    * 当只用 JavaScript 过渡的时候,在 enter 和 leave 中必须使用 done 进行回调。否则,它们将被同步调用,过渡会立即完成。
                    * */
                    Velocity(el, { translateX: '15px', rotateZ: '50deg' }, { duration: 600 })
                    Velocity(el, { rotateZ: '100deg' }, { loop: 2 })
                    Velocity(el, {
                        rotateZ: '45deg',
                        translateY: '30px',
                        translateX: '30px',
                        opacity: 0
                    }, { complete: done })
                },
                afterLeave: function (el) {
                    // 离开动画执行结束
                    console.log('afterLeave');
    
                },
                leaveCancelled: function (el) {
                    // 离开动画被取消 (只在v-show下生效)
                    console.log('leaveCancelled');
                },
            }
        });
    </script>
    

    当然还有一些细枝末节,例如<transition>组件mode属性的用法duration属性的用法,以及初始渲染动画appear,这些相对都比较好理解,Vue的官方文档也说的很详细,有例子,大家一看就明白了!

    vue动画官方文档:点击了解>>

    列表过渡

    开篇我们说过<transition-group> 是针对列表元素进行动画渲染,其本质与<transition>组件没有本质上的区别,不过却有几个特点需要额外注意:

    1. 不同于 <transition>,它会以一个真实元素呈现:默认为一个 <span>。你也可以通过 tag attribute 更换为其他元素。
    2. 过渡模式mode不可用,因为我们不再相互切换特有的元素。
    3. 内部元素总是需要提供唯一的 key attribute 值。
    4. CSS 过渡的类将会应用在内部的元素中,而不是这个组/容器本身。
    5. v-move特性,使用方式可参考v-enter。当列表(ul->li)内元素顺序发生变化的时候会被触发(顺序改变、添加元素、删除元素等)

    老规矩,翠花上代码:

      <style type="text/css">
        .list-complete-item {
          transition: all 1s;
          display: inline-block;
          margin-right: 10px;
        }
        .list-complete-enter, .list-complete-leave-to
        /* .list-complete-leave-active for below version 2.1.8 */ {
          opacity: 0;
          transform: translateY(30px);
        }
        .list-complete-leave-active {
          position: absolute;
        }
      </style>
      
       <div id="list-complete-demo" class="demo">
          <button v-on:click="shuffle">Shuffle</button>
          <button v-on:click="add">Add</button>
          <button v-on:click="remove">Remove</button>
          <transition-group name="list-complete" tag="p">
            <span
              v-for="item in items"
              v-bind:key="item"
              class="list-complete-item"
            >
              {{ item }}
            </span>
          </transition-group>
        </div>
        
        <script type="text/javascript">
          new Vue({
            el: '#list-complete-demo',
            data: {
              items: [1,2,3,4,5,6,7,8,9],
              nextNum: 10
            },
            methods: {
              randomIndex: function () {
                return Math.floor(Math.random() * this.items.length)
              },
              add: function () {
                this.items.splice(this.randomIndex(), 0, this.nextNum++)
              },
              remove: function () {
                this.items.splice(this.randomIndex(), 1)
              },
              shuffle: function () {
                this.items = _.shuffle(this.items)
              }
            }
          })
        </script> 
    

    ⒔ Vue的过渡 & 动画

    这是官网提供的一个实例,很好地描述了 <transition-group>。代码首先为 <transition-group> 指定了 name=list 用于标记动画渲染的过渡类名,然后指定 tag=p 表明当 <transition-group> 被渲染时会被替换为<p>标签,当我们点击 shuffleadd 或者 remove 按钮的时候,对列表数据进行修改,激活动画,开始执行。

    Vue.js 中的动画并不困难,但却略显杂乱,只要大家能够在大脑中将我们梳理的这些点都理解了,那么对 Vue.js 中动画的知识就掌握的差不多了。

    Vue的第三方动画库

    css动画库:

    Animate.css

    js动画库:

    • animejs
    • Velocity.js

    推荐这个Lodash库, 是一个一致性、模块化、高性能的 JavaScript 实用工具库,很多炫酷的效果都要配合运算,这个库很不错!

    总结

    除了上面列出的这两个动画库之外,还有很多被广泛使用的动画库,例如:tween.js不过总结起来动画库的使用无非就是分为两种:

    一种是直接通过类名指定写到的 css,比如 Animate.css,这种库使用简单,只需要赋值具体的类名就可以,缺点是动画都已经被制定好了,我们最多只能在原定的基础上进行部分修改。

    另一种是 通过 JavaScript 代码来进行动画的操控,比如 animejs、Velocity.js 等。这种库(框架)使用略显复杂,需要一定的学习成本,好处是能够解决的问题足够复杂,完全值得我们去投入时间来学习。


    起源地下载网 » ⒔ Vue的过渡 & 动画

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元