<template> <div :class="className"> <div :id="id" class="spiritChartBox"></div> </div> </template> <script> import { mapState } from "vuex"; import echarts from "@/utils/initEcharts"; import deepMerge from "@/utils/deepMerge"; export default { name: "spiritChart", props: { className: { type: String, default: "spiritChartBox" }, id: { type: String, default: "spiritChart" }, options: { type: Object, default: function() { return {}; } } }, data() { return { chart: null }; }, watch: { options() { this.setOption(); }, clientWidth() { this.setOption(); } }, mounted() { const self = this; self.initChart(); }, computed: { ...mapState({ clientWidth: state => state.init.clientWidth }) }, methods: { initChart() { const self = this; self.chart = echarts.init(document.getElementById(self.id)); window.addEventListener("resize", () => { self.chart.resize(); }); self.setOption(); }, setOption() { const self = this; const { options, clientWidth } = self; const maxData = 100; const spirit = "image://"; self.chart.setOption({ title: { text: "景区饱和度", x: "center", y: "15%", textStyle: { color: "#fff", fontSize: 24, fontWeight: 600 } }, tooltip: { show: false }, xAxis: { max: maxData, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: false } }, yAxis: { data: options.yAxisData || [], inverse: true, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { formatter: val => { const strArr = val.split("_"); return `{a|${strArr[0]}} {b|${strArr[1]}}`; }, rich: { a: { color: "#fff", fontSize: 12, lineHeight: 20 }, b: { color: "#fbee21", fontSize: 16 } } } }, grid: { top: "25%", height: "60%", "43%", right: "10%" }, series: [ { type: "pictorialBar", symbol: spirit, symbolRepeat: "fixed", symbolMargin: "15%", symbolClip: true, symbolSize: [15, 30], symbolBoundingData: maxData, data: options.seriesData || [], z: 10 }, { type: "pictorialBar", itemStyle: { normal: { opacity: 0.2 } }, animationDuration: 0, symbolRepeat: "fixed", symbolMargin: "15%", symbol: spirit, symbolSize: [15, 30], symbolBoundingData: maxData, data: options.seriesData || [], z: 5 } ] }); } } }; </script> <style scoped> .spiritChartBox { width: 100%; height: 100%; } </style>