本文实例为大家分享了javascript实现圆形进度条效果的具体代码,供大家参考,具体内容如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<style>
.itemwait{
position:absolute;
top : 0;
bottom:0;
left:0;
right:0;
margin: 0 auto;
}
.progress{
stroke-dasharray: 251;
stroke-dashoffset: 0;
/*
stroke-dasharray: 虚线
stroke-dashoffset: 偏移间隔
*/
}
</style>
</head>
<body>
<svg width="200" height="200" version="1.1" class='itemwait'>
<circle class='progress' cx="100" cy="50" r="40" stroke="pink" stroke-width="5" fill="transparent" />
<text class='text' x="100" y="50" fill='pink' text-anchor='middle' alignment-baseline='middle'>开始加载</text>
</svg>
</body>
<script async type='text/javascript'>
//js代码见下文
</script>
</html>
1.原生js实现
const loadingArr=[1,2,10,20,40,70,90,100]
let index=0
var timer=setInterval(()=>{
let total=document.querySelector('.progress').getTotalLength();
let progress=document.querySelector('.progress')
console.log(typeof total)
progress.style.strokeDashoffset=(total)*(1-loadingArr[index]/100)
if(index<=loadingArr.length){
document.querySelector('.text').textContent=`${loadingArr[index]}%`
}
index++
if(index===loadingArr.length){
clearInterval(timer)
document.querySelector('.text').textContent='加载完成'
}
},500)
2.jQuery实现
let index = 0
var $circle = $('.progress');
var r = $circle.attr('r');
var timer = setInterval(() => {
var total = Math.PI * (r * 2);
var pct = (1-index / 100) * total;
console.log(typeof pct,pct)
if (index <= 100) {
$('.text').text(`${index}%`);
$circle.css({ strokeDashoffset: pct });
}
index = index + 10
if (index > 100) {
$('.text').text('加载完成');
clearInterval(timer)
}
}, 500)
3.最初按照自己的想法实现
const loadingArr=[1,2,10,20,40,70,90,100]
let index=0
var timer=setInterval(()=>{
let total=document.querySelector('.progress').getTotalLength();
let progress=document.querySelector('.progress')
console.log(typeof total)
progress.style.strokeDashoffset=(total)*(1-loadingArr[index]/100)
$('.text').text(function(){
if(index<=loadingArr.length){
return `${loadingArr[index]}%`
}
})
index++
if(index===loadingArr.length){
clearInterval(timer)
$('.text').text('加载完成')
}
},500)
总结
知识点:svg绘图、js原生操作、jQuery
- stroke-dasharray: 虚线
- stroke-dashoffset: 偏移间隔
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持华域联盟。
您可能感兴趣的文章:
- javascript 进度条的几种方法
- js实现进度条的方法
- JavaScript实现网页加载进度条代码超简单
- js 进度条实现代码
- JS 进度条效果实现代码整理
- JS实现环形进度条(从0到100%)效果
- Javascript jquery css 写的简单进度条控件
- 用CSS+JS实现的进度条效果效果
- js实现音频控制进度条功能
- PHP中使用Session配合Javascript实现文件上传进度条功能
声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。


评论(0)