echarts柱形图+折线图混合案例

  1. 效果图
    柱形图
    折线图

  2. 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>

  1. 页面引用
<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
        },//进出园人数统计图分析
      }
  }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值