怎样使用jquery实现一个简易仪表盘?
Admin 2021-08-27 群英技术资讯 1363 次浏览
这篇文章给大家分享的是怎样使用jquery实现一个简易仪表盘,其实要实现一个简单的仪表盘并不困难,但是要计算好标码的位置,实现效果和代码如下,感兴趣的朋友就接着看吧。

*{
margin: 0;
padding: 0;
}
.rel{
display: flex;
justify-content:center;
align-items:center;
position: relative;
}
.bp{
border-radius:50% ;
border: 1px solid lightgray;
position:relative;
display: flex;
justify-content: center;
align-items: center;
transform: rotate(-45deg);
}
.kd{
position:absolute;
width: 100%;
font-size: 12px;
}
.point{
background-color:lightgray;
height: 100px;
width: 20px;
border-radius:100%;
transform: rotate(90deg);
transform-origin:10px 0px;
z-index: 9;
position: absolute;
transition: all 0.5s;
}
.kb{
position: absolute;
bottom: 20px;
font-size: 24px;
color: gray;
transition: all 0.5s;
}
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>做个仪表盘</title>
<script src="js/jquery-3.4.1.min.js"></script>
<script src="js/zgybp.js"></script>
<link href="css/zgybp.css" rel="stylesheet" type="text/css" />
<style>
#div{
border: 1px solid lightgray;
width: 90%;
height: 400px;
margin: 20px auto;
}
</style>
</head>
<body>
<div id="div"></div>
</body>
</html>
<script>
var temp = zgybp("div");
setInterval(function(){
var f = Math.floor(Math.random()*101);
temp.load(f);
},700)
</script>
var zgybp = function(id){
var $id = $("#"+id);
$id.addClass("rel");
var a = $id.width()>$id.height()?$id.height():$id.width();
$bp = $("<div class='bp'></div>");
$bp.appendTo($id);
$bp.css({
"width":a,
"height":a
})
//绘制刻度,只绘制3/4 270/100=2.7,每一个刻度都是2.7
for(var i =100;i>=0;i--){
$kd = $("<div class='kd'><span class='txt'>-</span></div>");
if(i%5==0){
$kd.find('.txt').text(i)
}
$kd.appendTo($bp);
$kd.css("transform","rotate("+(i*2.7)+"deg)");
}
$point = $("<div class='point'></div>")
$point.appendTo($bp)
$point.css({
"left":a/2,
"top":a/2
})
$kb = $("<div class='kb'>0</div>");
$kb.appendTo($id)
//然后将表盘转1/8的角度,就差不多了
return{
$id:$id,
$bp:$bp,
$point:$point,
$kb:$kb,
load:function(f){
var that = this;
f = f<0?0:f>100?100:f;
var temp = parseInt(f)*2.7;
that.$point.css({
"transform":"rotate("+(90+temp)+"deg)"
})
that.draw(f);
},
draw:function(f){
var that =this;
that.$kb.text(f);
}
}
}
以上就是关于使用jquery实现一个简易仪表盘的介绍了,上文有详细的注释,有需要的朋友可以参考上文代码,希望本文对大家学习jquery插件有帮助,想要了解更多jquery插件的使用,大家可以关注其他相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了uni-app 的模板语法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
本文主要介绍了React项目如何使用Element的方法步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
问题:canvas绘制图片,图片变模糊设定一个一定尺寸的canvas,我这里设置的画布大小是400px*400px。当一张图片完全画到画布上的时候,大概率都会出现图片模糊的情况。我拿下面一张图片画到canvas上作为例子,看上去应该比较明显的有模糊的感觉。单方面的去修改图片精度,换成更高清的图片,事实证明确实有一丢丢用
这篇文章主要介绍了Webpack的Loader和Plugin的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
js获取json对象中的key与value值的方法很简单,下面是javascript案例,代码。 scriptvarjsonObj={张三:中国,李四:美国};for(varkeyinjsonObj){console.log(key+===+jsonObj[key]);}/script 上面的javascript代码分别输出json对象的key和value字符串,如图所
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008