Vue transition实现点赞动画效果的示例

目录
  • 效果一览
  • 爱心效果
  • 数字滚动动画
  • 点赞动画

效果一览

爱心效果

材料:爱心图标两个,没有我这种 icon 组件的用 png 图片代替

<transition :name=" isLike ? 'zoom' : '' " mode="out-in">
    <!-- 爱心图标 -->
    <icon data="@icon/like.svg" color="#FF0000" v-if="isLike" key="like"></icon>
    <icon data="@icon/unlike.svg" color="#333333" v-else key="unlike"></icon>
</transition>

因为在点赞时有动画,取消点赞不要动画,所以 transition 的 name 属性需要根据 isLike 变量变化,当 isLiketrue 时,给他 zoom 动画,否则不给动画。动画模式是 out-in 即先出后进。原来的图标先从大变小,然后新图标再从小变大。

这里注意当两个切换的组件名称一致时,需要加 key 属性,以区分两个组件,否则动画不会生效

接下来写 css

/** 动画进行时的class **/
.zoom-enter-active, .zoom-leave-active {
    transition: all .15s cubic-bezier(0.42, 0, 0.34, 1.55);
}

/** 设置进场开始的状态和离场结束的状态,都是缩放到0 **/
.zoom-enter, .zoom-leave-to {
    transform: scale(0);
}

/** 设置进场结束的状态和离场开始的状态, 都是缩放到1 **/
.zoom-enter-to, .zoom-leave {
    transform: scale(1);
}

根据官方文档描述,.name-enter-active 和 .name-leave-active 会在动画进行时设置到 icon 组件的 class 中,所以这里我们设置 transition 的动画属性,时间以及曲线。

因为我们需要在放大时略微比 scale(1) 要大一点再回到正常大小,所以要自定义动画曲线 cubic-bezier(0.42, 0, 0.34, 1.55) 。这个曲线怎么来的呢?

打开 chrome 的调试面板,随便找个 dom 设置 transition-timing-function: ease; 然后点击 ease 旁边的曲线小图标

拖动拉杆就可以调整曲线

在动画快结尾的时候,使曲线超出结束点即可。

然后复制曲线面板下面的值 cubic-bezier(0.25, 0.1, 0.27, 1.32) 即可。

更多关于动画时间曲线的知识,这里就不赘述了,网上有很多相关知识。

关于缩放部分,按照上述 css 设定以及 mode="out-in" 动画模式是先出后进,在点赞时。

  1. 原来的爱心开始离场,此时原来爱心缩放状态为 1,即大小的 100%
  2. 爱心离场动画进行中,此时开始从 1 缩放到 0,即大小的 0%
  3. 原爱心离场完成,新爱心开始进场,此时新爱心缩放状态为 0
  4. 新爱心进场动画进行中,此时开始从 0 动画缩放到结束状态 1

当取消点赞的时候,isLikefalse,transition 的 name 就等于空字符串,此时就不会有动画了。

数字滚动动画

因为只是数字的变化,因此 transition 里只需要一个 div 即可。只是要注意 div 设置 key,以标识数据变动。

<div class="like-num-wrapper">
    <transition :name="item.is_like ? 'plus' : 'minus'">
        <div
                class="like-num"
                :style="{color: item['is_like'] ? 'red': '#333'}"
                :key="item['like_num']"
        >
            {{item['like_num']}}
        </div>
    </transition>
</div>
  .like-num-wrapper {
    position: relative;
    margin-left: 16px;
    text-align: end;
    font-size: 13px;
    height: 17px;
    overflow-y: hidden;

    .like-num {
      top: 0;
      left: 0;
      position: relative;
      line-height: 17px;
    }
  }

需要注意我们为了好计算上下滚动的距离,所以需要把数字的高度定死在 17px,接下来写 transition 的动画 class。我们通过点赞状态来判断应该用那一套动画,点赞时 transition 的 name 是 plus ,取消点赞时是 minus

// 点赞数字+1动画
.plus-enter-active, .plus-leave-active {
  transition: all .3s ease-in;
}

.plus-enter, .plus-leave {
  transform: translateY(0);
}

.plus-enter-to, .plus-leave-to {
  transform: translateY(-17px);
}

// 点赞数字-1动画
.minus-enter-active, .minus-leave-active {
  transition: all .3s ease-in;
}

.minus-enter {
  transform: translateY(-34px);
}

.minus-enter-to {
  transform: translateY(-17px);
}

.minus-leave {
  transform: translateY(0);
}

.minus-leave-to {
  transform: translateY(17px);
}

点赞动画

点赞动画很简单,在点赞时会在老的数字div下面生成一个新数字div。此时只需要让他们都往上移动 17px 即可。

因为取消点赞是数字从上往下滚动,所以需要让数字 1 的初始位置在 2 上面。所以写出如下代码,设定数字 1 的动画初始位置

.minus-enter {
  transform: translateY(-34px);
}

为什么是 -34px ?因为数字div的高度是 17px 往上移 17px 会和 2 重叠,那么数字 1 再往上移动 17px 就会出现在 2 的上面。-17-17 = 34 这一切都发生在电光火石之间。

接下来在 .minus-enter-to 中位移到 -17px 就可以实现 1 往下滚动到 2 这个效果了。

数字 2 的离场动画就简单多了 直接从 0 到 17px 就可以滚出去了。

至此整个点赞效果就完成了

以上就是Vue transition实现点赞动画效果的示例的详细内容,更多关于vue transition实现点赞效果的资料请关注我们其它相关文章!

(0)

相关推荐

  • vue组件 keep-alive 和 transition 使用详解

    1.keep-alive 能在组件切换过程中将状态保留在内存中,防止重复渲染DOM. 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们.和 相似, 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中. 当组件在 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行. include: 字符串或正则表达式.只有匹配的组件会被缓存. exclude: 字符串或正则表达式.任何匹配的组件都不会被缓存. // 组件 export

  • vue transition 在子组件中失效的解决

    错误代码: 子组件: <template> <div v-show="showMine"> <div class="mask" @click.self="onMask"></div> <transition name="slide-fade"> <div class="my_group" v-if="showMine"&g

  • 在Vue中创建可重用的 Transition的方法

    Vue.js中的transition确实很棒.毫无疑问,它们可以非常轻松地让应用程序栩栩如生,但是通常必须在每个项目中从头开始编写它们,甚至还需要引入animate.css之类的CSS库来使它们功能更强大. 如果我们可以将它们封装到组件中,并在多个项目中简单地重用它们,结果会怎样呢?我们将介绍几种定义transition的方法,并深入研究如何使它们真正可重用. 原始transition组件和CSS 定义transition的最简单方法是使用transition·或transition-group

  • 如何在Vue中实现Svelte的Defer Transition

    最近观看了Rich Harris的<Rethinking Reactivity>视频,惊叹于Svelte框架的高效同时,还发现了Vue所不具备的一些关于动画的原生支持-defer transitions. 先看看Svelte所谓的defer transition的效果吧. 这是使用Svelte做的Todo Demo应用.整个todo分成3个部分.输入部分,todo列表和done列表.当点击todo列表中的条目时,相应条目会被"移动"到done列表,反之亦然. 在这里,条目从

  • vue使用transition组件动画效果的实例代码

    transition文档地址 定义一个背景弹出层实现淡入淡出效果 <template> <div> <button @click="show = !show"> Toggle </button> <transition name="fadeBg"> <div class="bg" v-if="show">hello</div> </tra

  • vue 组件中使用 transition 和 transition-group实现过渡动画

    前言 记一次vue 组件中使用 transition 和 transition-group 设置过渡动画,总结来说可分为分为 name 版, js 钩子操作类名版, js 钩子操作行内样式版... template模板结构 // 单个元素 <transition name="自定义名字"> <p v-if="show">hello</p> </transition> // 列表元素: 注意group的直接子元素是v-f

  • Vue过渡效果之CSS过渡详解(结合transition,animation,animate.css)

    以一个toggle按钮控制p元素显隐为例,如果不使用过渡效果,则如下所示 <div id="demo"> <button v-on:click="show = !show">Toggle</button> <p v-if="show">蓝色理想</p> </div> <script> new Vue({ el: '#demo', data: { show: tru

  • 详解vue中使用transition和animation的实例代码

    以前写页面注重在功能上,对于transition和animation是只闻其声,不见其人,对于页面动画效果心理一直痒痒的.最近做活动页面,要求页面比较酷炫,终于有机会认真了解了. transition:英文过渡的意思,作用是过渡效果:animation:英文活泼.生气.激励,动画片就是animation film,作用是动画效果. transition在w3school的实例: //将鼠标悬停在一个 div 元素上,逐步改变表格的宽度从 100px 到 300px: div { width:10

  • Vue的transition-group与Virtual Dom Diff算法的使用

    开始 这次的题目看上去好像有点奇怪:把两个没有什么关联的名词放在了一起,正如大家所知道的,transition-group就是Vue的内置组件之一主要用在列表的动画上,但是会跟Virtual Dom Diff算法有什么特别的联系吗?答案明显是有的,所以接下来就是代码分解. 缘起 主要是最近对Vue的Virtual Dom Diff算法有点模糊了,然后顺手就打开了电脑准备温故知新:但是很快就留意到代码: // removeOnly is a special flag used only by <t

  • 关于vue状态过渡transition不起作用的原因解决

    总所周知,vue中的transition标签可以方便得进行动画过渡,使用的方法也很简单. <transition name="你要的名字"> 过渡的元素... </transition> 这里需要主要一点的是:过渡的元素只能是以下之一: 条件渲染 (使用 v-if) 条件展示 (使用 v-show) 动态组件 组件根节点 常用的过渡名称有fade等 你可以这样用 <transition name="fade"> 过渡的元素...

随机推荐