Files
emsfront/src/views/ems/dzjk/home/WeekChart.vue

98 lines
2.1 KiB
Vue
Raw Normal View History

2025-08-06 17:34:35 +08:00
<template>
<el-row style="background:#fff;margin-top:30px;">
<el-col :xs="24" :sm="24" :lg="24">
<el-card shadow="always" class="common-card-container common-card-container-body-no-padding">
<div slot="header">
<span class="card-title">一周充放曲线</span>
</div>
<div style="height: 310px" id="weekChart"></div>
</el-card>
</el-col>
</el-row>
</template>
<script>
import * as echarts from 'echarts'
import resize from '@/mixins/ems/resize'
export default {
mixins: [resize],
data() {
return {
chart: null
}
},
mounted() {
this.$nextTick(() => {
this.initChart()
})
},
beforeDestroy() {
if (!this.chart) {
return
}
this.chart.dispose()
this.chart = null
},
methods: {
initChart() {
this.chart = echarts.init(document.querySelector('#weekChart'))
},
2025-08-06 23:06:12 +08:00
showLoading(){
this.chart && this.chart.showLoading()
},
setOption(data,unit) {
2025-08-06 17:34:35 +08:00
const source = [['日期','充电量','放电量']]
2025-08-06 23:06:12 +08:00
data.forEach(item=>{
2025-08-06 17:34:35 +08:00
source.push([item.ammeterDate, item.chargedCap,item.disChargedCap])
})
this.chart.setOption({
2025-08-06 23:06:12 +08:00
color:['#FFBD00','#3C81FF','#05AEA3'],
2025-08-06 17:34:35 +08:00
tooltip: {
trigger: 'axis',
axisPointer: { // 坐标轴指示器,坐标轴触发有效
type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
2025-08-06 23:06:12 +08:00
legend: {
left: 'center',
bottom: '10',
2025-08-06 17:34:35 +08:00
},
xAxis: {
type: 'category',
2025-08-06 23:06:12 +08:00
name:unit,
nameLocation:'center'
2025-08-06 17:34:35 +08:00
},
2025-08-06 23:06:12 +08:00
yAxis: [{
2025-08-06 17:34:35 +08:00
type: 'value',
2025-08-06 23:06:12 +08:00
name:'充电量/放电量kWh',
2025-08-06 17:34:35 +08:00
axisLine: {
lineStyle:{
color: '#333333',
2025-08-06 23:06:12 +08:00
},
onZero:false
2025-08-06 17:34:35 +08:00
}
2025-08-06 23:06:12 +08:00
}],
2025-08-06 17:34:35 +08:00
dataset:{
source
},
series: [
{
2025-08-06 23:06:12 +08:00
yAxisIndex:0,
2025-08-06 17:34:35 +08:00
type: 'line',
2025-08-06 23:06:12 +08:00
},
{
yAxisIndex:0,
2025-08-06 17:34:35 +08:00
type: 'line',
2025-08-06 23:06:12 +08:00
},
]
2025-08-06 17:34:35 +08:00
})
2025-08-06 23:06:12 +08:00
this.chart.hideLoading()
2025-08-06 17:34:35 +08:00
}
}
}
</script>