使用SVG实现进度条
主要使用了svg的两个属性:
stroke-dasharray:通过数组值创建虚线,可填单个或多个值
stroke-dasharray = '10' // 表示生成长度为10、间隔为10的重复虚线 stroke-dasharray = '10, 5' // 表示生成长度为10、间隔为5的重复虚线 stroke-dasharray = '10,5,15' // 表示生成长度为10、间隔为5、长度为15,然后间隔为10、长度为5、间隔为15的重复虚线
stroke-dashoffset:虚线偏移量
stroke-dashoffset = '10' // 虚线整体向左偏移10个单位 storke-dashoffset = '-10' // 虚线整体向右偏移10个单位
主要实现代码如下:
<svg width="300" height="300"> <line x1="10" y1="10" x2="260" y2="10" stroke="#F2F2F2" strokeWidth="15"></line> <!-- 进度条底图,这里为了简便画了一条直线,可自行替换成需要的svg路径 --> <line x1="10" y1="10" x2="260" y2="10" stroke="#1890FF" strokeWidth="15" ref={pathRef}></line> <!-- 进度条填充图,与底图路径一致,填充色调整为所需进度颜色即可 --> </svg>
const len = pathRef.current.getTotalLength(); // 通过pathRef获取到填充图的长度,js可给标签设置id、通过id获取到对应dom pathRef.current.style.strokeDasharray = len; pathRef.current.style.strokeDashoffset = len - len * (percent / 100); // percent为对应进度
效果如下:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了