一、效果图如下:
二、代码配置如下:
(1)父组件
<template>
<div class="page-con">
<div class="main-con">
<item />
</div>
</div>
</template>
<script>
import item from '../bigdata/components/item.vue'
export default {
components: {
item
}
}
</script>
<style lang="scss" scoped>
.page-con {
width: 100%;
height: 100%;
.main-con {
width: 32%;
height: 33%;
}
}
</style>
(2)子组件:
<template>
<div class="main">
<div class="volume" id="volume2"></div>
</div>
</template>
<script>
import echarts from "echarts";
export default {
data() {
return {
myChart: null,
};
},
mounted() {
this.$nextTick(() => {
this.drawBar();
});
//获取数据。
this.reloadChart();
//自适应浏览器。
window.addEventListener("resize", () => {
this.reloadChart();
});
},
//组件销毁。
destroyed() {
this.disposeChart();
},
methods: {
drawBar() {
this.myChart = this.$echarts.init(document.getElementById("volume2"));
const dataSource = [
{ value: "8", unit: "个", name: "事件1" },
{ value: "1", unit: "个", name: "事件2" },
{ value: "2", unit: "个", name: "事件3" },
{ value: "3", unit: "个", name: "事件4" },
{ value: "8", unit: "个", name: "事件5" },
];
let option = {
backgroundColor: "#00000d",
tooltip: {
trigger: "axis",
},
grid: {
containLabel: true,
left: "4%",
right: "5%",
bottom: "2%",
top: "30",
},
xAxis: {
name: "",
show: true,
type: "value",
splitLine: {
show: false,
lineStyle: {
color: "#61738C",
type: "dashed",
},
},
axisLabel: {
textStyle: {
color: "#b3c7c9",
fontSize: this.fontSize(0.35),
},
},
axisLine: {
show: true, //不显示x轴
lineStyle: {
color: "#15588b",
},
},
axisTick: {
show: false, //不显示刻度
},
},
yAxis: [
{
type: "category",
inverse: true,
axisLabel: {
margin: 10,
color: "#b3c7c9",
fontWeight: 400,
fontSize: this.fontSize(0.35),
interval: 0,
formatter: function (value) {
let str = "";
let num = 4; //每行显示字数
let valLength = value.length; //该项x轴字数
let rowNum = Math.ceil(valLength / num); // 行数
if (rowNum > 1) {
for (let i = 0; i < rowNum; i++) {
let temp = "";
let start = i * num;
let end = start + num;
temp = value.substring(start, end) + "";
str += temp;
}
return str;
} else {
return value;
}
},
},
splitLine: {
show: false,
lineStyle: {
color: "#61738C",
type: "dashed",
},
},
axisLine: {
show: true, //不显示x轴
lineStyle: {
color: "#15588b",
},
},
axisTick: {
show: false, //不显示刻度
},
data: dataSource.map((item) => item.name),
},
],
series: [
{
type: "bar",
barMinWidth: "10",
backgroundStyle: {
opacity: 1,
color: "#1f4365",
},
yAxisIndex: 0,
data: dataSource.map((item) => item.value),
barWidth: 20,
stack: "2",
itemStyle: {
normal: {
//颜色渐变函数 前四个参数分别表示四个位置依次为左、下、右、上
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
{
offset: 0,
color: "#00d5fc",
},
{
offset: 1,
color: "#1280eb",
},
]),
},
},
markLine: {
symbol: "none", //去掉箭头
data: [
{
type: "average",
name: "平均数",
},
],
label: {
position: "start",
formatter: ({ name }) => {
return `{a|${"平均数"}}`;
},
align: "center",
rich: {
a: {
color: "#fff",
backgroundColor: "#00a8ff",
padding: [6, 8],
borderColor: "#7cd1e0",
borderWidth: 0,
borderRadius: 10,
},
},
},
lineStyle: {
color: "#00a8ff",
},
},
},
{
type: "pictorialBar",
data: dataSource.map((item) => item.value),
xAxisIndex: 0,
yAxisIndex: 0,
zlevel: 99,
symbol:
"image://",
symbolRotate: 0,
symbolSize: [15, 20],
symbolPosition: "end",
symbolOffset: [8, 0],
itemStyle: {
color: "#1dfffc",
shadowColor: "rgba(29,255,252, 0.8)",
shadowBlur: 10,
},
tooltip: {
show: false,
},
},
],
};
this.myChart.setOption(option);
},
//字体自适应。
fontSize(res) {
let clientWidth =
window.innerWidth ||
document.documentElement.clientWidth ||
document.body.clientWidth;
if (!clientWidth) return;
let fontSize = 40 * (clientWidth / 1920);
return res * fontSize;
},
//销毁图表。
disposeChart() {
if (this.myChart) {
this.myChart.dispose();
}
},
//重新加载图表。
reloadChart() {
this.disposeChart();
this.drawBar();
},
},
};
</script>
<style lang="scss" scoped>
.main {
width: 100%;
height: 100%;
.volume {
width: 100%;
height: 100%;
}
}
</style>