微信小程序通过自定义animate-numbers组件实现进入页面时数字跳动效果

 更新时间:2025年01月26日 09:30:10   作者:trabecula_hj  
文章介绍了如何在微信小程序中实现进入页面时的数字跳动效果,通过自定义一个名为`animate-numbers`的组件来实现这一功能,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧

微信小程序中实现进入页面时数字跳动效果

1. 组件定义,新建animate-numbers组件

1.1 index.js

// components/animate-numbers/index.js
Component({
  properties: {
    number: {
      type: Number,
      value: 0
    },
    duration: {
      type: Number,
      value: 1000
    }
  },
  data: {
    displayNumber: 0,
    animationFrameId: null
  },
  observers: {
    'number': function (newNumber) {
      this.animateNumber(newNumber);
    }
  },
  methods: {
    animateNumber(targetNumber) {
      const start = this.data.displayNumber;//旧值
      const end = targetNumber;//新值
      const duration = this.properties.duration;
      const increment = (end - start) / (duration / 16); // 假设每秒60帧,每帧间隔约16ms
      let current = start;
      if(this.data.animationFrameId){
        clearInterval(this.data.animationFrameId);
      }
      const animate = () => {
        current += increment;
        if ((increment > 0 && current >= end) || (increment < 0 && current <= end)) {
          clearInterval(this.data.animationFrameId);
          this.setData({ displayNumber: end });
        } else {
          this.setData({ displayNumber: Math.round(current) });
        }
      };
      this.data.animationFrameId = setInterval(animate, 16);
    }
  },
  // 组件被移除时清除定时器
  detached() {
    clearInterval(this.data.animationFrameId);
  }
});

1.2 wxml

<view>{{displayNumber}}</view>

1.3 wxss

page {
  font-size: 48rpx;
  font-weight: bold;
}

2. 使用组件

"animate-numbers": "../../../components/animate-numbers/index"

 <animate-numbers number="{{attendanceInfo.month_avg_days}}" duration="1000"/>

到此这篇关于微信小程序中实现进入页面时数字跳动效果(自定义animate-numbers组件)的文章就介绍到这了,更多相关小程序数字跳动内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Javascript 设计模式(二) 闭包

    Javascript 设计模式(二) 闭包

    本来应该是第二章,接口,但因为闭包实在不懂,所以先看看闭包
    2010-05-05
  • 微信小程序webview实现长按点击识别二维码功能示例

    微信小程序webview实现长按点击识别二维码功能示例

    这篇文章主要介绍了微信小程序webview实现长按点击识别二维码功能,结合实例形式分析了webview二维码识别相关操作技巧,需要的朋友可以参考下
    2019-01-01
  • JS使用插件cryptojs进行加密解密数据实例

    JS使用插件cryptojs进行加密解密数据实例

    这篇文章主要介绍了JS使用插件cryptojs进行加密解密数据,结合完整实例形式分析了javascript基于加密插件实现加密解密功能的相关操作技巧,需要的朋友可以参考下
    2017-05-05
  • javascript中判断json的方法总结

    javascript中判断json的方法总结

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON数据不须要任何特殊的API或工具包,接下来跟着小编学习js中判断json的方法吧
    2015-08-08
  • javascript中style.left和offsetLeft的用法说明

    javascript中style.left和offsetLeft的用法说明

    本篇文章主要是对javascript中style.left和offsetLeft的用法进行了说明介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-03-03
  • javascript里绝对用的上的字符分割函数总结

    javascript里绝对用的上的字符分割函数总结

    本节主要介绍了javascript里比较实用的字符分割函数的使用,需要的朋友可以参考下
    2014-07-07
  • TypeScript数组去重的20种实现方式

    TypeScript数组去重的20种实现方式

    文章主要介绍了使用TypeScript实现数组去重的20种方法,从基础循环、内置数组方法、集合容器、排序后去重和递归与特殊等五个策略进行分类,并详细讲解了每种方法的实现原理、适用场景以及性能特点,此外,还提供了选择不同去重方法的建议和实际项目中的应用示例
    2026-05-05
  • js项目中双向数据绑定的简单实现方法

    js项目中双向数据绑定的简单实现方法

    双向数据绑定指的就是,绑定对象属性的改变到用户界面的变化的能力,反之亦然,下面这篇文章主要给大家介绍了关于js项目中双向数据绑定的简单实现方法,需要的朋友可以参考下
    2021-08-08
  • Js和JQuery获取鼠标指针坐标的实现代码分享

    Js和JQuery获取鼠标指针坐标的实现代码分享

    这篇文章主要介绍了Js和JQuery获取鼠标指针坐标的实现代码分享,本文直接给出实现的代码,需要的朋友可以参考下
    2015-05-05
  • javascript垃圾收集机制与内存泄漏详细解析

    javascript垃圾收集机制与内存泄漏详细解析

    本文是对javascript中的垃圾收集机制与内存泄漏进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11

最新评论