答案:使用javaScript通过定时更新dom实现数字递增动画。首先在html中创建显示数字的元素,如<div id=”counter”>0</div>;接着用js编写animateCounter函数,接收元素ID、目标值和动画时长,利用requestAnimationFrame按帧逐步增加数值,每帧间隔约16ms以达到60fps流畅效果;通过计算总步数和每步增量控制进度,并在结束时确保显示目标值;页面加载后调用函数启动动画,可同时为多个元素设置不同递增效果;配合css可美化样式,如字体、颜色及过渡动画,适用于数据看板等场景。

实现数字递增动画,通常使用 javascript 控制 HTML 元素的文本内容,通过逐步增加数值来形成动画效果。HTML 本身没有“函数”概念,但结合 JS 可以轻松实现动态数据展示。下面介绍如何用原生 JS 实现一个简单的数字递增动画。
1. 基础结构:HTML 容器
先在 HTML 中设置一个用于显示递增数字的元素:
<div id="counter">0</div>
2. 核心逻辑:JavaScript 动画函数
使用 setTimeout 或 requestAnimationFrame 实现平滑递增。以下是一个通用的递增函数示例:
立即学习“前端免费学习笔记(深入)”;
function animateCounter(elementId, targetValue, duration = 2000) { const element = document.getElementById(elementId); const incrementTime = 16; // 约每帧 16ms(60fps) const totalSteps = Math.floor(duration / incrementTime); let currentStep = 0; const startValue = 0; const stepValue = (targetValue - startValue) / totalSteps; <p>function update() { currentStep++; let currentValue = startValue + stepValue * currentStep;</p><pre class='brush:php;toolbar:false;'>if (currentValue >= targetValue) { element.innerText = targetValue; return; } element.innerText = Math.floor(currentValue); requestAnimationFrame(update);
}
requestAnimationFrame(update); }
这个函数接收三个参数:
- elementId:要更新的 HTML 元素 ID
- targetValue:目标数值(如 1000)
- duration:动画持续时间(毫秒,默认 2000ms)
3. 调用动画函数
页面加载后启动动画:
// 页面加载完成后执行 window.onload = function () { animateCounter("counter", 888, 1500); // 从 0 增加到 888,耗时 1.5 秒 };
4. 扩展:多个数字同时递增
可以为多个元素分别调用函数:
<div id="users">0</div> <div id="sales">0</div> <div id="revenue">0</div> <p>window.onload = function () { animateCounter("users", 1250, 2000); animateCounter("sales", 960, 1800); animateCounter("revenue", 50000, 2500); };</p>
5. 样式美化建议
配合 CSS 提升视觉效果:
#counter { font-size: 2em; font-weight: bold; color: #007acc; transition: color 0.3s; }
可添加进入动效或颜色变化增强表现力。
基本上就这些。通过 JS 控制 DOM 更新数值,结合定时机制就能做出流畅的数字递增动画,适合用于数据看板、统计展示等场景。不复杂但容易忽略细节,比如浮点数处理和结束时强制设为目标值。


