答案:通过HTML内联SVG结合JavaScript控制stroke-dashoffset实现环形进度条,利用circle元素绘制背景和进度圆,用stroke-dasharray与stroke-dashoffset配合周长计算进度显示,通过JavaScript动态更新偏移值和文本内容,并添加CSS过渡动画使变化平滑,rotate(-90deg)使进度从顶部开始,最终实现轻量可复用的环形进度条组件。

制作环形进度条可以通过 HTML 结合 SVG 内联实现,无需依赖外部文件,直接在 HTML 中使用 SVG 绘制图形,并通过 JavaScript 动态控制进度。下面详细介绍如何用内联 SVG 创建一个可自定义的环形进度条。
1. SVG 环形进度条的基本结构
SVG 的 元素结合描边(stroke)和描边偏移(stroke-dasharray 与 stroke-dashoffset)可以实现环形进度效果。原理是绘制一个圆形轮廓,然后通过虚线描边控制可见部分长度,模拟进度。
0%
说明:
r=”50″:半径为 50,圆心在 (60,60),因此周长 = 2πr ≈ 314stroke-dasharray=”314″:设置虚线总长度等于周长stroke-dashoffset:初始为 314 表示无显示;值越小,显示越多
2. 使用 JavaScript 控制进度
通过函数动态计算 dashoffset 并更新文本,实现进度变化。
立即学习“前端免费学习笔记(深入)”;
function setProgress(percent) { const circle = document.querySelector('.progress-circle'); const text = document.querySelector('text'); const offset = 314 * (1 - percent / 100); circle.style.strokeDashoffset = offset; text.textContent = percent + '%';}
调用示例:
setProgress(75); // 设置为 75%
3. 添加样式和动画效果
可以在 CSS 中添加过渡动画,让进度更平滑。
.progress-circle { transition: stroke-dashoffset 0.8s ease; transform: rotate(-90deg); transform-origin: 50% 50%;}
说明:
transition 让描边变化有动画rotate(-90deg) 使进度从顶部开始
4. 完整示例代码
svg { display: block; margin: 20px auto; } .progress-circle { transition: stroke-dashoffset 0.8s ease; transform: rotate(-90deg); transform-origin: center; } 0%
function setProgress(percent) {const circle = document.querySelector('.progress-circle');const text = document.querySelector('text');const offset = 314 * (1 - percent / 100);circle.style.strokeDashoffset = offset;text.textContent = percent + '%';}
// 示例:设置进度setProgress(60);
基本上就这些。通过内联 SVG 和简单的 JavaScript 函数,就能实现一个轻量、可复用的环形进度条,适合嵌入网页任意位置,无需额外资源加载。
以上就是html函数如何制作环形进度条 html函数SVG图形的内联应用的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1585077.html
微信扫一扫
支付宝扫一扫