<template>
<div :id="id" class="main" :style="{ width: width, height: height }" :ref="id"></div>
</template>
<script>
import * as echarts from "echarts";
export default {
name: "roseChart",
data() {
return {
myEchart: null,
name: "苹果",
value: 0,
value1: 10
};
},
props: {
width: {
type: String,
default: "100%"
},
height: {
type: String,
default: "70px"
}, // 数据(数组)
typeAnalysisData: {
type: Array,
default: () => []
},
id: {
type: String,
default: "roseChart"
} // 是否显示提示(方框)
},
methods: {
drawChart() {
let timer = null;
timer = setTimeout(() => {
if (
this.myEchart != null &&
this.myEchart != "" &&
this.myEchart != undefined
) {
this.myEchart.dispose(); //销毁
}
if (!this.$refs[this.id]) return;
this.myEchart = echarts.init(this.$refs[this.id]);
let option = {
// backgroundColor: "#1B232E",
grid: {
left: "10px",
right: "10px",
bottom: "40px"
},
xAxis: {
show: false,
type: "value",
boundaryGap: [0, 0],
max: 100
},
yAxis: {
type: "category",
axisTick: "none",
axisLine: "none",
show: true,
position: "right",
axisLabel: {
// 后面文字位置
padding: [-35, 5, 0, 0],
align: "right",
verticalAlign: "top",
textStyle: {
color: "#fff",
fontSize: 12
},
formatter: this.value1 + "家"
},
data: [this.value]
},
series: [
{
// 进度
data: [{ name: this.name, value: this.value }],
name: this.name,
type: "bar",
barWidth: "24px",
showBackground: true,
backgroundStyle: {
borderRadius: 2,
// 整个进度条颜色
// color: "#252F3D",
// borderColor: "#252F3D",
// borderWidth:5,
opacity: 1
},
itemStyle: {
color: {
x: 1,
y: 0,
x2: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: "#2AA9D9" // 0% 处的颜色
},
{
offset: 1,
color: "#2AA9D9"
}
]
},
borderRadius: 2
},
label: {
show: true,
position: "insideTopLeft",
fontSize: 12,
fontFamily: "Source Han Sans CN-Regular",
fontWeight: 400,
color: "#FFFFFF",
// 前面文字位置
padding: [-25, 0, 0, 0],
formatter: "{b}"
},
emphasis: {
disabled: true
},
markPoint: {
symbol:
"image://",
symbolSize: [30, 48],
label: { show: false },
symbolOffset: [0, 0],
data: [{ name: "最大值", type: "max" }]
}
}
]
};
this.myEchart.setOption(option);
}, 500);
}
},
mounted() {
this.drawChart();
window.addEventListener("resize", this.drawChart);
},
watch: {
typeAnalysisData: {
handler(newName, oldName) {
this.$nextTick(() => {
this.drawChart();
window.addEventListener("resize", this.drawChart);
});
},
deep: true
}
},
destroyed() {
window.removeEventListener("resize", this.drawChart);
}
};
</script>
<style lang="scss" scoped>
</style>