-
效果图
-
vue柱形图+折线图组件
<template>
<div ref="two"></div>
</template>
<script>
import echarts from "echarts";
import "echarts/lib/chart/pie";
import "echarts/lib/chart/line";
import "echarts/lib/chart/bar";
import "echarts/lib/chart/map";
import "echarts/lib/chart/effectScatter";
import "echarts/lib/chart/scatter";
import "echarts/lib/chart/lines";
import "echarts/lib/chart/pictorialBar";
import "echarts/lib/component/markPoint";
import "echarts/lib/component/geo";
export default {
props: {
propsData: { type: Array, default: () => [] },
},
data() {
return {};
},
mounted() {
this.two();
},
methods: {
two() {
const two = echarts.init(this.$refs.two);
const {
xname,
legendName,
serisesData,
title,
colorList,
barGap,
} = this.propsData;
const serises = [];
for (let i = 0; i < legendName.length; i++) {
serises.push({
name: legendName[i],
type: "bar",
data: serisesData[i],
barWidth : 18,//柱图宽度
barGap: barGap,
itemStyle: {
normal: {
color: colorList[i],
barBorderRadius: [30, 30, 0, 0],
},
},
});
}
const option = {
backgroundColor: "#fff",
title: {
text: title,
x: "25",
y: "10",
textStyle: {
fontWeight: "700",
fontSize: 20,
color: "#444",
},
},
grid: {
left: "3%",
right: "3%",
bottom: "23%",
top: "15%",
containLabel: true,
},
legend: {
bottom: 15,
textStyle: {
color: "#666",
padding: [2, 0, 0, 0],
},
itemGap: 30,
itemWidth: 10,
itemHeight: 20,
data: legendName,
},
tooltip: {
trigger: "axis",
axisPointer: {
// 坐标轴指示器,坐标轴触发有效
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
},
backgroundColor: "#fff",
borderColor: "#ccc",
borderWidth: 1,
padding: 10,
formatter: function (val) {
var temp = val.map((item, index) => {
return `<span style="display:inline-block; width:10px;height:10px;background:
${val[index].color};margin:0 10px 0 0; border-radius:3px"> </span>
${val[index].seriesName}: ${val[index].data}人<br/>`;
});
return `${
val[0].axisValueLabel
}<br/>${temp.toString().replace(/[,]/g, "")}`;
},
textStyle: {
fontSize: 14,
color: "#666",
},
},
toolbox: {
show: true,
top: 10,
right: 25,
itemSize: 37,
itemGap:0,
feature: {
magicType: {
type: [ "bar","line"],
icon: {
bar:
"image://",
line:
"image://",
},
},
saveAsImage: {
icon:
"image://",
},
},
},
xAxis: [
{
type: "category",
data: xname,
axisLabel: {
interval:0,
// margin: 20,
color: "#666",
textStyle: {
fontSize: 12,
},
},
axisLine: {
lineStyle: {
color: "#666",
},
},
axisTick: {
show: true,
inside: true,
},
},
],
yAxis: [
{
min: 0,
// max: 100,
axisLabel: {
// formatter: '{value}%',
color: "#666",
textStyle: {
fontSize: 14,
},
},
axisLine: {
lineStyle: {
color: "#666",
},
},
axisTick: {
inside: true,
},
splitLine: {
show: false,
},
},
],
dataZoom: [
{
show: true,
height: 30,
xAxisIndex: [0],
bottom: 60,
start: 0,
end: 100,
handleStyle: {
color: "#5B3AAE",
},
},
{
type: "inside",
show: true,
height: 15,
},
],
series: serises,
};
two.setOption(option,true);
window.addEventListener("resize", function () {
two.resize();
});
},
}
};
</script>
<style>
</style>
- 页面引用
<rich-bar-charts :key="richBarCharts" style="height: 500px;" :propsData="touristStock"></rich-bar-charts>
import RichBarCharts from "../components/echarts/richBarCharts";
export default {
components: { RichBarCharts},
data () {
return {
richBarCharts:1,
touristStock:{
xname:['景点1','景点2','景点3','景点4','景点5','景点6','景点7','景点8'],
legendName:['进园人数','出园人数'],
serisesData:[[520,520,205,200,520,764,520,550],[520,764,520,550,520,520,205,200]],
title:'进出园人数分析',
colorList:['#01ce8d','#ffa922'],
barGap:1
},//进出园人数统计图分析
}
}
}