网站首页 > 技术文章 正文
本文实例为大家分享了Vue使用echarts定制特殊仪表盘的具体代码,供大家参考,具体内容如下
实现的效果:(初始化以及浏览器resize的时候数字和弧形条均为递增动画)
HTML部分:
< !-- 为ECharts准备一个具备大小(宽高)的Dom -->
< div class="main-echarts-contianer"
ref="main">
< /div>
CSS部分:
.main-echarts-contianer {
width: 480px;
height: 320px;
display: flex;
align-items: center;
justify-content: center;
}
JS部分:
drawClockChart () {
// 指定图表的配置项和数据
let option = {
'series': [
{
'name': '个人指标',
'type': 'gauge',
'radius': '65%',
'startAngle': '240',
'endAngle': '-60',
// 图表的刻度分隔段数
'splitNumber': 5,
// 图表的轴线相关
'axisLine': {
'show': true,
'lineStyle': {
'color': [
[
0.9,
new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [{
offset: 0,
color: '#FFD900'
},
{
offset: 1,
color: '#FF8000'
}
])
],
[1, '#56606E']
],
'width': 15
}
},
// 图表的刻度及样式
'axisTick': {
'lineStyle': {
'color': '#0F1318',
'width': 2
},
'length': 15,
'splitNumber': 1
},
// 图表的刻度标签(20、40、60等等)
'axisLabel': {
'distance': -8,
'textStyle': {
'color': '#9E9E9E'
}
},
// 图表的分割线
'splitLine': {
'show': false
},
// 图表的指针
'pointer': {
'show': false
},
// 图表的数据详情
'detail': {
'formatter': function (params) {
return '{title|' + '总体得分}' + '\n' + '{score|' + params + '}'
},
'offsetCenter': [0, 0],
'rich': {
'title': {
'fontSize': 12,
'color': '#9E9E9E',
'lineHeight': 30
},
'score': {
'fontSize': 27,
'color': '#fff'
}
}
},
// 图表的标题
'title': {
'offsetCenter': [0, '90%'],
'color': '#fff',
'fontSize': 14
},
'data': [{
'name': '完成',
'value': 31
}]
},
{
'name': '外层线',
'type': 'gauge',
'radius': '72%',
'startAngle': '240',
'endAngle': '-60',
'center': ['50%', '50%'],
'axisLine': {
'lineStyle': {
'width': 1,
'color': [[1, '#56606E']]
}
},
'splitLine': {
'length': -6,
'lineStyle': {
'opacity': 0
}
},
'axisLabel': {
'show': false
},
'axisTick': {
'splitNumber': 1,
'lineStyle': {
'opacity': 0
}
},
'detail': {
'show': false
},
'pointer': {
'show': false
}
}
]
}
let tempVal = 0
clearInterval(this.clockChartTimer)
this.clockChartTimer = setInterval(() => {
if (tempVal > this.myIvstrAbility) {
clearInterval(this.clockChartTimer)
// 最后转到最终数据的地方
option.series[0].data[0].value = this.myIvstrAbility
option.series[0].axisLine.lineStyle.color[0][0] = this.myIvstrAbility / 100
// 使用刚指定的配置项和数据显示图表
this.myChart.setOption(option)
// 初始化渲染完成
this.renderCompleted = true
return
}
option.series[0].data[0].value = tempVal
option.series[0].axisLine.lineStyle.color[0][0] = tempVal / 100
// 使用刚指定的配置项和数据显示图表。
this.myChart.setOption(option)
tempVal++
}, 20)
// 此处监听浏览器的resize,重新渲染图表
let that = this
window.addEventListener("resize", function () {
clearTimeout(that.resizeTimer)
that.resizeTimer = setTimeout(() => {
myChart.resize()
}, 500)
})
}
以上就是本文的全部内容,希望对大家的学习有所帮助。
简单介绍Vue使用echarts定制特殊的仪表盘 | 《Linux就该这么学》 (linuxprobe.com)
- 上一篇: 「重磅」Xilinx下载文件破解及LUT在线可编程研究
- 下一篇: vue+echarts使用
猜你喜欢
- 2024-11-27 echarts图形报表的入门案例
- 2024-11-27 Echarts仿电梯运行图
- 2024-11-27 微信小程序开发之wepy 引入echarts统计图方法 亲测可用
- 2024-11-27 yarn安装echarts教程
- 2024-11-27 微信小程序使用 ECharts
- 2024-11-27 4、echarts 如何画图?(必会)
- 2024-11-27 JavaScript 前端数据可视化——ECharts.js
- 2024-11-27 vue+echarts使用
- 11-27echarts图形报表的入门案例
- 11-27Echarts仿电梯运行图
- 11-27微信小程序开发之wepy 引入echarts统计图方法 亲测可用
- 11-27yarn安装echarts教程
- 11-27微信小程序使用 ECharts
- 11-274、echarts 如何画图?(必会)
- 11-27JavaScript 前端数据可视化——ECharts.js
- 11-27vue+echarts使用
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)