feat(视图): echarts组件封装,初步实现

This commit is contained in:
junjie 2021-03-11 15:06:13 +08:00
parent faeedeb1e9
commit 00bce0ee7e
4 changed files with 95 additions and 57 deletions

View File

@ -15,6 +15,23 @@ export const BASE_BAR = {
series: [] series: []
} }
export default { export const BASE_LINE = {
BASE_BAR title: {
text: ''
},
tooltip: {},
legend: {
data: []
},
xAxis: {
data: []
},
yAxis: {
type: 'value'
},
series: []
}
export default {
BASE_BAR, BASE_LINE
} }

View File

@ -0,0 +1,65 @@
<template>
<div class="Echarts" style="height: 100%;display: flex;margin-top: 10px;">
<div id="echart" style="width: 100%;height: 80vh;" />
</div>
</template>
<script>
import { BASE_BAR, BASE_LINE } from '../chart/chart'
export default {
name: 'ChartComponent',
props: {
chart: {
type: Object,
required: true
}
},
data() {
return {}
},
watch: {
chart() {
this.drawEcharts()
}
},
mounted() {
},
methods: {
drawEcharts() {
const chart = this.chart
let chart_option = {}
// todo type
if (chart.type === 'bar') {
chart_option = JSON.parse(JSON.stringify(BASE_BAR))
} else if (chart.type === 'line') {
chart_option = JSON.parse(JSON.stringify(BASE_LINE))
}
// console.log(chart_option);
if (chart.data) {
chart_option.title.text = chart.title
chart_option.xAxis.data = chart.data.x
chart.data.series.forEach(function(y) {
chart_option.legend.data.push(y.name)
chart_option.series.push(y)
})
}
// console.log(chart_option);
this.myEcharts(chart_option)
},
myEcharts(option) {
// domecharts
var myChart = this.$echarts.init(document.getElementById('echart'))
//
setTimeout(myChart.setOption(option, true), 500)
window.onresize = function() {
myChart.resize()
}
}
}
}
</script>
<style scoped>
</style>

View File

@ -5,7 +5,7 @@
<span <span
class="item-axis" class="item-axis"
> >
{{ item.name }}<span class="summary-span">({{ $t('chart.'+item.summary) }})</span><i class="el-icon-arrow-down el-icon--right" /> {{ item.name }}<span class="summary-span">{{ $t('chart.'+item.summary) }}</span><i class="el-icon-arrow-down el-icon--right" />
<span /> <span />
<el-dropdown-menu slot="dropdown"> <el-dropdown-menu slot="dropdown">
<el-dropdown-item icon="el-icon-notebook-2"> <el-dropdown-item icon="el-icon-notebook-2">
@ -50,7 +50,7 @@ export default {
}, },
methods: { methods: {
summary(param) { summary(param) {
console.log(param) // console.log(param)
this.item.summary = param.type this.item.summary = param.type
this.$emit('onQuotaSummaryChange', this.item) this.$emit('onQuotaSummaryChange', this.item)
}, },

View File

@ -31,7 +31,7 @@
@start="start1" @start="start1"
> >
<transition-group> <transition-group>
<span v-for="item in dimension" :key="item.id" class="item" @click="click1(item)">{{ item.name }}</span> <span v-for="item in dimension" :key="item.id" class="item">{{ item.name }}</span>
</transition-group> </transition-group>
</draggable> </draggable>
</div> </div>
@ -47,7 +47,7 @@
@start="start1" @start="start1"
> >
<transition-group> <transition-group>
<span v-for="item in quota" :key="item.id" class="item" @click="click2(item)">{{ item.name }}</span> <span v-for="item in quota" :key="item.id" class="item">{{ item.name }}</span>
</transition-group> </transition-group>
</draggable> </draggable>
</div> </div>
@ -131,9 +131,7 @@
</el-row> </el-row>
</el-row> </el-row>
<div class="Echarts" style="height: 100%;display: flex;margin-top: 10px;"> <chart-component :chart="chart" />
<div id="echart" style="width: 100%;height: 80vh;" />
</div>
</el-row> </el-row>
</el-col> </el-col>
</el-row> </el-row>
@ -143,13 +141,13 @@
<script> <script>
import { post } from '@/api/dataset/dataset' import { post } from '@/api/dataset/dataset'
import draggable from 'vuedraggable' import draggable from 'vuedraggable'
import { BASE_BAR } from '../chart/chart'
import DimensionItem from '../components/DimensionItem' import DimensionItem from '../components/DimensionItem'
import QuotaItem from '../components/QuotaItem' import QuotaItem from '../components/QuotaItem'
import ChartComponent from '../components/ChartComponent'
export default { export default {
name: 'ChartEdit', name: 'ChartEdit',
components: { QuotaItem, DimensionItem, draggable }, components: { ChartComponent, QuotaItem, DimensionItem, draggable },
data() { data() {
return { return {
table: {}, table: {},
@ -173,7 +171,8 @@ export default {
arr2: [ arr2: [
{ id: 11, name: '容量' } { id: 11, name: '容量' }
], ],
moveId: -1 moveId: -1,
chart: {}
} }
}, },
computed: { computed: {
@ -225,26 +224,6 @@ export default {
this.quota = response.data.quota this.quota = response.data.quota
}) })
}, },
click1(item) {
// console.log(item);
const c = this.view.xaxis.filter(function(ele) {
return ele.id === item.id
})
// console.log(c);
if (c && c.length === 0) {
this.view.xaxis.push(item)
}
},
click2(item) {
// console.log(item);
const c = this.view.yaxis.filter(function(ele) {
return ele.id === item.id
})
// console.log(c);
if (c && c.length === 0) {
this.view.yaxis.push(item)
}
},
get(id) { get(id) {
if (id) { if (id) {
post('/chart/view/get/' + id, null).then(response => { post('/chart/view/get/' + id, null).then(response => {
@ -290,20 +269,8 @@ export default {
this.view = response.data this.view = response.data
this.view.xaxis = this.view.xaxis ? JSON.parse(this.view.xaxis) : [] this.view.xaxis = this.view.xaxis ? JSON.parse(this.view.xaxis) : []
this.view.yaxis = this.view.yaxis ? JSON.parse(this.view.yaxis) : [] this.view.yaxis = this.view.yaxis ? JSON.parse(this.view.yaxis) : []
// echart
const chart = response.data this.chart = response.data
const chart_option = JSON.parse(JSON.stringify(BASE_BAR))
// console.log(chart_option);
if (chart.data) {
chart_option.title.text = chart.title
chart_option.xAxis.data = chart.data.x
chart.data.series.forEach(function(y) {
chart_option.legend.data.push(y.name)
chart_option.series.push(y)
})
}
// console.log(chart_option);
this.myEcharts(chart_option)
}) })
} else { } else {
this.view = {} this.view = {}
@ -391,7 +358,6 @@ export default {
}, },
quotaSummaryChange(item) { quotaSummaryChange(item) {
console.log(item)
// item // item
this.view.yaxis.forEach(function(ele) { this.view.yaxis.forEach(function(ele) {
if (ele.id === item.id) { if (ele.id === item.id) {
@ -399,16 +365,6 @@ export default {
} }
}) })
this.save() this.save()
},
myEcharts(option) {
// domecharts
var myChart = this.$echarts.init(document.getElementById('echart'))
//
setTimeout(myChart.setOption(option, true), 500)
window.onresize = function() {
myChart.resize()
}
} }
} }
} }