三分钟简单学习/复习 vue transition

过渡动画transition

  • 首先确认过渡是单元素过渡 (包括单个结点和统一时间渲染多个结点中的一个) 还是列表(li)过渡动画,单元素使用 列表使用

  • 添加过渡模式mode使过渡更加流畅,如果未采用,会出现离开过渡的元素和进入过渡的元素被同时绘制,模式有in-out 和 out-in 两种,in-out:新元素先进行过渡,完成之后当前元素过渡离开。out-in:当前元素先进行过渡,完成之后新元素过渡进入。

  • 例:<transition name="fade" mode="out-in">...</transition>

  • 使用<transiton-group>时会默认渲染为 ,最好使用tag进行指定为需要的标签如:<transiton-group name="mylist" tag="ul"> </transiton-group>

  • <transition-group> 组件还有一个特殊之处。不仅可以进入和离开动画,还可以改变定位。要使用这个新功能只需了解新增的 v-move 特性,它会在元素的改变定位的过程中应用,它将元素从之前的位置平滑过渡新的位置。

  • 用css写过渡的效果时常用的类名有v-enter v-leave-to v-enter-active v-leave-active ,当你的过渡没有name属性时,v-就是类名的默认前缀,当你使用了name属性时,需要通过 name 属性来自定义前缀,比如说<transition name="fade" mode="out-in">...</transition>里,name是fade,那么定义过渡动画时如下:

    /*css:*/
    .fade-enter-active {
      transition: all .3s ease;
    }
    .leave-active {
      transition: all .8s cubic-bezier(1.0, 0.5, 0.8, 1.0);
    }
    .fade-enter, .slide-fade-leave-to {
      transform: translateX(10px);
      opacity: 0;
    }
    
  • 下图是v-enter v-leave-to v-enter-active v-leave-active的形象描述

在这里插入图片描述

  • 可以使用钩子函数实现半场动画
  • 过渡可以放进组件里进行复用
  • 可以配合使用Animate.css 和 Velocity.js
  • 然后放两个例子,分别是使用transition 和transition-group
<div id="demo">
  <button v-on:click="show = !show">
    Toggle
  </button>
  <transition name="fade">
    <p v-if="show">hello</p>
  </transition>
</div>
new Vue({
  el: '#demo',
  data: {
    show: true
  }
})
.fade-enter-active, .fade-leave-active {
  transition: opacity .5s;
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
  opacity: 0;
}
  <button v-on:click="add">Add</button>
  <button v-on:click="remove">Remove</button>
  <transition-group name="list" tag="p">
    <span v-for="item in items" v-bind:key="item" class="list-item">
      {{ item }}
    </span>
  </transition-group>
</div>
new Vue({
  el: '#list-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)
    },
  }
})
.list-item {
  display: inline-block;
  margin-right: 10px;
}
.list-enter-active, .list-leave-active {
  transition: all 1s;
}
.list-enter, .list-leave-to
/* .list-leave-active for below version 2.1.8 */ {
  opacity: 0;
  transform: translateY(30px);
}
发布了46 篇原创文章 · 获赞 12 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/yuanfangyoushan/article/details/97489255