我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue transition组件简单实现数字滚动

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue transition组件简单实现数字滚动

实现效果

Scrip

<template>
  <button @click="addCount">点我滚动数字</button>
  <div class="roll-container">
    <transition name="roll">
      <div class="roll-number" :key="count">{{ count }}</div>
    </transition>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';
export default defineComponent({
  setup() {
    const count = ref(0);
    let click_time = Date.now();
    function addCount() {
      if (Date.now() - click_time < 300) return;
      click_time = Date.now();
      count.value += 1;
    }
    return {
      count,
      addCount,
    };
  },
});
</script>
<style>
.roll-container {
  position: relative;
  text-align: center;
  font-size: 120px;
  line-height: 1em;
  color: #fff;
  height: 1em;
  min-width: 1em;
  max-width: 3em;
  background: #000000;
  overflow: hidden;
}
.roll-number {
  
  
  width: 100%;
}
.roll-enter-active,
.roll-leave-active {
  transition: all .3s;
  position: absolute;
  top: 0;
}
.roll-leave-to {
  top: -1em;
}
.roll-enter-active {
  top: 1em;
}
.roll-enter-to {
  top: 0;
}
</style>
      

使用vuetransition组件,来实现一个数字滚动效果,其实不仅可以是数字滚动,还可以是文字、段落滚动,代码片段使用了定位做的,还可以使用transform,只是一种思路,不限制方案。

布局

没有别人写的东西炫酷,我都不知道怎么写内容了,布局没啥好讲的,我这里会有一个容器包裹内部滚动的数字,主要是用于隐藏内部滚动的数字超出的部分,代码如下:

  <div class="roll-container">
    <transition name="roll">
      <div class="roll-number" :key="count">{{ count }}</div>
    </transition>
  </div>

样式如下:

.roll-container {
  position: relative;
  text-align: center;
  font-size: 120px;
  line-height: 1em;
  color: #fff;
  height: 1em;
  min-width: 1em;
  max-width: 3em;
  background: #000000;
  overflow: hidden;
}
.roll-number {
  width: 100%;
}

这里的细节就是transition组件是用于元素显隐状态切换使用的,一般用于v-ifv-show,还有transition-group也是一样的,不过transition-group是用于多个元素上的,可以作用在列表上,对于列表的数据新增、删除可以触发过渡效果。

而我这里使用keykey发生改变可以强制元素的更新,可以完整的触发组件的生命周期,就达到了元素销毁和创建的整个过程,也可以触发过渡,key的作用老生常谈了,可以网上去查查资料,用得好可以有很多巧妙的作用。

动画

动画是使用vuetransition组件的css class过渡方式,官网上的文档过渡的生命周期描述的很清楚,我就不搬运了,vue transiton组件

过渡css代码:


.roll-enter-active,
.roll-leave-active {
  transition: all .3s;
  position: absolute;
  top: 0;
}

.roll-leave-to {
  top: -1em;
}

.roll-enter-active {
  top: 1em;
}

.roll-enter-to {
  top: 0;
}

代码就这么一丢丢,只要理解了过渡的生命周期,就可以控制各种效果,我这里这个应该是入门级代码,这里的细节就是需要定义一个过渡的起点,因为使用的是定位,如果不设置起点是没有过渡效果的,如果是用变换(transform)可以不用设置起点,为什么这个就和css相关了,不在这次的谈论范围之内。

逻辑控制

逻辑控制主要是要动画执行完成之后才能再次修改变量,否则就会有重叠,闪动等,造成动画不连贯,我这里动画执行时间是300毫秒,所以也就是300毫秒只能修改一次状态。

    const count = ref(0);
    // 缓存第一次状态修改的时间
    let click_time = Date.now();
    function addCount() {
      // 300ms 只能执行一次
      if (Date.now() - click_time < 300) return;
      // 重置状态修改的时间
      click_time = Date.now();
      count.value += 1;
    }

这个就是一个很简单的逻辑控制,这里是通过点击来修改的,这里也可以通过定时器去处理。

总结

以前要做一个数字滚动需要弄一个插件,插件代码也多,通过js进行控制处理,一般都是把0-9的数字放一排,然后滚动,滚动完成把头部的数字放到尾部,而使用transition组件只要这么一丢丢代码就可以完成相同的功能,如果在加上vue3新出的css变量绑定,还可以做到过渡动画执行时间的动态控制。

以上就是Vue transition组件简单实现数字滚动的详细内容,更多关于Vue transition数字滚动的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue transition组件简单实现数字滚动

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

简单方法实现Vue 无限滚动组件示例

这篇文章主要为大家介绍了简单方法实现Vue 无限滚动组件示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

vue怎么实现简单无缝滚动效果

本篇内容介绍了“vue怎么实现简单无缝滚动效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!效果实现思路在vue中如何复制一份列表出来呢且不
2023-06-29

React如何实现数字滚动组件numbers-scroll

本篇内容主要讲解“React如何实现数字滚动组件numbers-scroll”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“React如何实现数字滚动组件numbers-scroll”吧!首先给大
2023-07-05

vue-seamless-scroll实现简单自动无缝滚动且添加对应点击事件的简单整理

vue-seamless-scroll是一个基于Vue.js的简单无缝滚动组件,基于requestAnimationFrame实现,配置多满足多样需求,目前支持上下左右无缝滚动,单步滚动,及支持水平方向的手动切换功能,本节介绍,vue添加vue-seamless-scroll实现自动无缝滚动的效果,并对应添加点击事件
2023-01-03

React实现数字滚动组件numbers-scroll的示例详解

数字滚动组件,也可以叫数字轮播组件,这个名字一听就是非常普通常见的组件。本文将利用React实现这一组件,感兴趣的小伙伴可以了解一下
2023-03-10

Vue3基于countUp.js实现数字滚动的插件

本文主要介绍了Vue3基于countUp.js实现数字滚动的插件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-17

Vue金融数字格式化(并保留小数)数字滚动效果实现

这篇文章主要介绍了Vue金融数字格式化(并保留小数)数字滚动效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-16

怎么在Vue中使用better-scroll组件实现横向滚动功能

怎么在Vue中使用better-scroll组件实现横向滚动功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、滚动的实现原理better-scroll的滚动
2023-06-15

如何使用Vue代码实现一个上下滚动加载组件

本篇内容主要讲解“如何使用Vue代码实现一个上下滚动加载组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Vue代码实现一个上下滚动加载组件”吧!组件代码// scrollLoader.
2023-07-04

Vue封装数字框组件实现流程详解

这篇文章主要介绍了Vue封装数字框组件实现流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-05-16

编程热搜

目录