常用echarts示例

案例一:(双坐标,双柱图)

常用echarts示例_第1张图片

 代码及注释:

  this.chartOption = { 
            legend: {
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)", // 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#0B9295", // 图例的文字颜色
                    padding: [3, 0, 0, 0],
                },
                data: ["老人数", "预警数"],
            },
            tooltip: {
                trigger: "axis",
                axisPointer: {
                    type: "shadow"
                }
            },
            grid: {
                left: "0%",
                right: "0%",
                bottom: "3%",
                containLabel: true
            },
            xAxis: {
                type: "category",
                // data: yearList,
                data:[
                    "市区", "高邮市", "仪征市", "江都区", "宝应县"
                ],
                splitLine: {//分割线配置
                    show: false
                },
                axisLabel: {  // x轴线文字的样式
                    textStyle: {
                        color: "#B4FFF5",
                        fontSize: 12
                    },
                },
                axisTick: {
                    show: false
                },
                axisLine: {//x轴线的颜色以及宽度
                    show: true,
                    lineStyle: {
                        color: "#3AB2B4",
                        type: "solid",
                        width: 1
                    }
                }
            },
            yAxis: [
                {
                    type: "value",
                    name:"老人数",
                    nameTextStyle:{ // name的样式
                        color:"#0B9295"
                    },
                    splitLine: {//分割线配置
                        show: false,
                        lineStyle: {
                            color: "#3AB2B4",
                            type: "solid",
                            width: 0
                        }
                    },
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },
                    axisLabel: { // y轴的文字样式
                        textStyle: {
                            color: "#B4FFF5"
                        },
                    }

                },
                {
                    type: "value",
                    name:"预警数",
                    nameTextStyle:{
                        color:"#0B9295"
                    },
                    position:"right",
                    splitLine: {//分割线配置
                        show: false,
                        lineStyle: {
                            color: "rgba(0, 112, 107, 0.1)"
                        }
                    },
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },
                    axisLabel: {
                        show:true,
                        textStyle: {
                            color: "#B4FFF5"
                        },
                    }
                },
                {
                    type: "value",
                    gridIndex: 0,
                    min: 50,
                    max: 100,
                    splitNumber: 8,
                    splitLine: {
                        show: false,
                        color: ["#ccc"], // 分隔线颜色。
                        width: 1, // 分隔线线宽
                        type: "dashed", // 线的类型
                        opacity: 1 // 图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。
                    },
                    axisLine: {
                        show: false
                    },
                    axisTick: {
                        show: false
                    },
                    axisLabel: {
                        show: false
                    },
                    splitArea: {
                        show: true,
                        areaStyle: {
                            color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.05)"]
                        }
                    }
                }

            ],
            series: [
                {
                    name: "老人数",
                    type: "bar",
                    color: "#4FE2CF",
                    nameStyle:{
                        width:100
                    },
                    yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
                    barWidth:"14px", // 柱子的宽度
                    itemStyle: {
                        normal: {
                            
                            barBorderRadius: [2, 2, 2, 2],
                            lineStyle: {
                                width: 3
                            }
                        }
                    },
                    data:[
                        "12",
                        "2",
                        "3",
                        "2",
                        "45",
                    ]
                },
                {
                    name: "预警数",
                    type: "bar",
                    color: "#FF9F48",
                    barWidth:"14px", // 柱子的宽度
                    yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
                    showAllSymbol: true, //显示所有图形。
                    itemStyle: {
                        normal: {
                            
                            barBorderRadius: [2, 2, 2, 2],
                            lineStyle: {
                                width: 3
                            }
                        }
                    },
                    data:[
                        "123",
                        "34",
                        "56",
                        "23",
                        "566",
                    ]
                },


            ]
        };

案例二:(堆叠柱图+折线图)

 代码及注释:

 this.chartOption = { 
            legend: {
                itemHeight: 6,
                itemWidth: 16,
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#0B9295", // 图例的文字颜色
                    padding: [3, 0, 0, 0],
                },
                data: ["处理数", "预警数", "处理率"],
            },
            tooltip: {
                trigger: "axis",
                axisPointer: { // 鼠标移上去时,触发后的样式
                    type: "shadow"
                }
            },
            grid: {
                left: "3.5%",
                right: "0%",
                bottom: "3%",
                containLabel: true
            },
            xAxis: {
                type: "category",
                // data: yearList,
                data:[
                    "市区", "高邮市", "仪征市", "江都区", "宝应县"
                ],
                splitLine: {//分割线配置
                    show: false
                },
                axisLabel: {  // x轴线文字的样式
                    textStyle: {
                        color: "#B4FFF5",
                        fontSize: 12
                    },
                },
                axisTick: {
                    show: false
                },
                axisLine: {//x轴线的颜色以及宽度
                    show: true,
                    lineStyle: {
                        color: "#3AB2B4",
                        type: "solid",
                        width: 1
                    }
                }
            },
            yAxis: [
                {
                    type: "value",
                    name:"预警数/处理数",
                    nameTextStyle:{ // name的样式
                        color:"#0B9295"
                    },
                    splitLine: {//分割线配置
                        show: false,
                        lineStyle: {
                            color: "#3AB2B4",
                            type: "solid",
                            width: 0
                        }
                    },
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },
                    axisLabel: { // y轴的文字样式
                        textStyle: {
                            color: "#B4FFF5"
                        },
                    }
                },
                {
                    type: "value",
                    name:"处理率",
                    nameTextStyle:{
                        color:"#0B9295"
                    },
                    position:"right",
                    splitLine: {//分割线配置
                        show: false,
                        lineStyle: {
                            color: "rgba(0, 112, 107, 0.1)"
                        }
                    },
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },
                    axisLabel: {
                        show:true,
                        textStyle: {
                            color: "#B4FFF5"
                        },
                    }
                },
                {
                    type: "value",
                    gridIndex: 0,
                    min: 50,
                    max: 100,
                    splitNumber: 8,
                    splitLine: {
                        show: false
                    },
                    axisLine: {
                        show: false
                    },
                    axisTick: {
                        show: false
                    },
                    axisLabel: {
                        show: false
                    },
                    splitArea: {
                        show: true,
                        areaStyle: {
                            color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.05)"]
                        }
                    }
                }

            ],
            series: [
                {
                    name: "处理数",
                    type: "bar",
                    color: "#4FE2CF",
                    // stack设置柱状图堆叠,stack后面要跟同样的名字
                    stack:"Search Engine",
                    nameStyle:{
                        width:100
                    },
                    yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
                    barWidth:"14px", // 柱子的宽度
                    itemStyle: {
                        normal: {
                            
                            lineStyle: {
                                width: 3
                            }
                        }
                    },
                    data:[
                        "12",
                        "2",
                        "3",
                        "2",
                        "45",
                    ]
                },
// yAxisIndex: 0, 因为处理数和预警数在一起  所以将这两个的值设置为同一个,这样 处理数和预警数会同时使用左侧的 y轴的坐标
                {
                    name: "预警数",
                    type: "bar",
                    // stack设置柱状图堆叠,stack后面要跟同样的名字
                    stack:"Search Engine",
                    color: "#FF9F48",
                    barWidth:"14px", // 柱子的宽度
                    yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
                    showAllSymbol: true, //显示所有图形。
                    itemStyle: {
                        normal: {
                            
                            barBorderRadius: [2, 2, 2, 2],
                            lineStyle: {
                                width: 3
                            }
                        }
                    },
                    data:[
                        "123",
                        "34",
                        "56",
                        "23",
                        "566",
                    ]
                },
                {
                    name: "处理率",
                    type: "line",
                    color: "#ff4d1c",
                    barWidth:"14px", // 柱子的宽度
                    yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
                    showAllSymbol: true, //显示所有图形。
                    smooth: true, //平滑曲线显示
                    symbol:"circle",
                    symbolSize: 9, //标记的大小
                    itemStyle: {
                        normal: {
                            lineStyle: {
                                width: 1
                            }
                        }
                    },
                    data:[
                        "123",
                        "34",
                        "56",
                        "23",
                        "566",
                    ]
                },

            ]
        };

案例三:

常用echarts示例_第2张图片

代码及注释:

 this.chartOption = { 
            legend: {
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#0B9295", // 图例的文字颜色
                    padding: [3, 0, 0, 0],
                },
                data: ["实时用电量", "近七天平均用电量"],
            },
            tooltip: {
                trigger: "axis",
                  
            },
            grid: {
                left: "0%",
                right: "0%",
                bottom: "3%",
                containLabel: true
            },
            xAxis: {
                type: "category",
                // data: yearList,
                data:[
                    "11:00", "11:20", "11:40", "12:00", "12:20", "12:40", "13:00"
                ],
                splitLine: {//分割线配置
                    show: false
                },
                axisLabel: {  // x轴线文字的样式
                    textStyle: {
                        color: "#B4FFF5",
                        fontSize: 12
                    },
                },
                axisTick: {
                    show: false
                },
                axisLine: {//x轴线的颜色以及宽度
                    show: true,
                    lineStyle: {
                        color: "#3AB2B4",
                        type: "solid",
                        width: 1
                    }
                }
            },
            yAxis: [
                {
                    type: "value",
                    name:"单位:kwh",
                    splitNumber: 5,
                    nameTextStyle:{ // name的样式
                        color:"#0B9295"
                    },
      
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },

                    splitLine: {
                        lineStyle: {
                            color: "#3AB2B4",
                            opacity: 0.3,
                            type: "solid",
                        },
                    },
                    axisLabel: {
                        textStyle: {
                            color: "#B4FFF5",
                        },
                    },
                },

            ],
            series: [
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name:"近七天平均用电量",
                    smooth: true, // 平滑的折线
                    itemStyle: {
                        normal: {
                            color: "#ff9f48", //改变折线点的颜色
                            lineStyle: {
                                color: "#ff9f48", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: {
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(255, 159, 72, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(255, 159, 72, 0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: [480, 390, 500, 260, 320, 660, 320],
                },
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name:"实时用电量",
                    smooth: true, // 平滑的折线
                    itemStyle: {
                        normal: {
                            color: "#4fe2cf", //改变折线点的颜色
                            lineStyle: {
                                color: "#4fe2cf", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: { // 折线下的区域颜色
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(79, 226, 207, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(79, 226, 207,0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: [340, 510, 540, 600, 500, 600, 640],
                },
                
               
            ],
        };

案例四:(动态前进图)

常用echarts示例_第3张图片

import Util from "@/util/echarts/common"; // 引入echarts公共的类\
 
export default class Bar extends Util {
    constructor(el, option) {
        super(el, option); // 继承父类,echarts公共类的值
        this.init(); // 初始化
    }
 
    init() {
        this.myChart = this.$e.init(this.$el);
        this.setCharts();
        var index = 0; //播放所在下标

        setTimeout(()=>{
            this.myChart.dispatchAction({
                type: "showTip",
                seriesIndex:0,
                dataIndex: index //默认显示第几个
            });
            index++;
            if(index > 96) { // 此处的96为x轴的数据长度
                index = 0;
            }
        });
        // 改变this指向
        var option = this.chartOption;
        var myChart = this.myChart;

        setInterval(function () {
            // 每次向后滚动一个,最后一个从头开始。
            if (option.dataZoom[0].endValue === 96 ) { // 此处的96为x轴的数据长度
                option.dataZoom[0].endValue = 15; 
                option.dataZoom[0].startValue = 0;
            }
            else {
                option.dataZoom[0].endValue = option.dataZoom[0].endValue + 1;
                option.dataZoom[0].startValue = option.dataZoom[0].startValue + 1;
            }
            myChart.setOption(option, true); // 将配置项加到echarts中
        }, 2000);
        window.addEventListener("resize", () => { // 监听屏幕缩放,使echarts同样缩放
            this.myChart.resize();
        });
    }
 
    setCharts() { // 配置echarts
        this.chartOption = { 
            legend: {
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",
                textStyle: {
                    fontSize: 12,
                    color: "#0B9295", // 图例的文字颜色
                    padding: [3, 0, 0, 0],
                },
                data: ["实时用电量", "近七天平均用电量"],
                left:'right',
            },
            tooltip: {
                trigger: "axis",
                  
            },
            dataZoom: [
                {
                    show:false, // 隐藏下拉条
                    startValue: 0, // 从头开始。
                    endValue: 9  // 一次性展示9个。
                }
            ],
            grid: {
                left: "3%",
                right: "0%",
                bottom: "3%",
                containLabel: true
            },
            xAxis: {
                type: "category",
                // data: yearList,
                data:[
                    "11:00", "11:20", "11:40", "12:00", "12:20", "12:40", "13:00","11:00", "11:20", "11:40", "12:00", "12:20", "12:40", "13:00"
                ],
                splitLine: {//分割线配置
                    show: false
                },
                axisLabel: {  // x轴线文字的样式
                    textStyle: {
                        color: "#B4FFF5",
                        fontSize: 12
                    },
                },
                axisTick: {
                    show: false
                },
                axisLine: {//x轴线的颜色以及宽度
                    show: true,
                    lineStyle: {
                        color: "#3AB2B4",
                        type: "solid",
                        width: 1
                    }
                }
            },
            yAxis: [
                {
                    type: "value",
                    name:"单位:kwh",
                    splitNumber: 5,
                    nameTextStyle:{ // name的样式
                        color:"#0B9295"
                    },
      
                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine:{ // 取消整个刻度线
                        show:false
                    },

                    splitLine: {
                        lineStyle: {
                            color: "#3AB2B4",
                            opacity: 0.3,
                            type: "solid",
                        },
                    },
                    axisLabel: {
                        textStyle: {
                            color: "#B4FFF5",
                        },
                    },
                },

            ],
            series: [
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name:"近七天平均用电量",
                    smooth: true, // 平滑的折线
                    itemStyle: {
                        normal: {
                            color: "#ff9f48", //改变折线点的颜色
                            lineStyle: {
                                color: "#ff9f48", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: {
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(255, 159, 72, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(255, 159, 72, 0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: [340, 51, 540, 600, 500, 60, 60,30, 50, 50, 60, 50, 60, 60],
                },
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name:"实时用电量",
                    smooth: true, // 平滑的折线
                    itemStyle: {
                        normal: {
                            color: "#4fe2cf", //改变折线点的颜色
                            lineStyle: {
                                color: "#4fe2cf", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: { // 折线下的区域颜色
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(79, 226, 207, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(79, 226, 207,0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: [340, 510, 540, 600, 500, 600, 640,340, 510, 540, 600, 500, 600, 640],
                },
                
               
            ],
        };
    }
}

案例五:雷达图
常用echarts示例_第4张图片

代码:

常用echarts示例_第5张图片

   mounted(){
        // 渲染echarts
        // 监听屏幕,实现自适应
        window.onresize = () => {
            this.myChart.resize();
        };
        setTimeout(()=>{
            this.initChart()
        },1000)
    },
    methods:{
        initChart(){
            this.myChart = echarts.init(document.getElementById('chart'))
            const option = {
                color: ["#1b7cff", "#6dcd62"],
                title: {
                    text: '企业能力分析',
                    textStyle:{
                        color: '#2E3A55',
                        fontWeight: 500,
                        fontSize: '15px',
                    }
                },
                tooltip:{
                    show: true,
                    // trigger: 'item', 
                    // confine: true,
                    // textStyle: {
                    //     color: "#fff",
                    //     fontSize: 13
                    // }
                },
                legend: {
                    itemHeight: 8,
                    itemWidth: 8,
                    data: ['企业得分占比', '市均值得分占比'],
                    x: "right",
                    textStyle: {
                        fontSize: 10,
                        color: "#B2BACC", // 图例的文字颜色
                    }
                },
                radar: {
                    // shape: 'circle',
                    center: ['50%', '59%'],//位置
                    name: {
                        textStyle: {
                            color: '#6A7284',
                            fontSize:'12px'
                        }
                    },
                    indicator: [
                    { name: '创新人才', max: 6500 },
                    { name: '创新投入', max: 16000 },
                    { name: '创新产出', max: 30000 },
                    { name: '企业成长性', max: 38000 },
                    { name: '创新平台', max: 52000 },
                    { name: '创新活动', max: 25000 },
                    { name: '创新成果', max: 25000 }
                    ]
                },
                series: [
                    {
                    type: 'radar',
                    // label:{
                    //     show: true,
                    //     position: 'top',
                    //     color: 'rgba(111,82,38, .8)',
                    //     fontSize: 13,
                    //     fontWeight: 'bold'
                    // },
                    symbolSize: 6 , // 雷达区域节点的大小
                    // // 区域的颜色
                    // itemStyle: {
                    //     borderWidth: 2,
                    //     opacity: 1
                    // },
                    // 雷达区域的背景颜色的样式
                    areaStyle: {
                        opacity: 0.2
                    },
                    data: [
                        {
                        value: [4200, 3000, 20000, 35000, 50000, 18000],
                        name: '企业得分占比'
                        },
                        {
                        value: [5000, 14000, 28000, 26000, 42000, 21000],
                        name: '市均值得分占比'
                        }
                    ]
                    }
                ]
             }
            this.myChart.setOption(option, true);
         }
    }

案例六:自定义tooltip提示

常用echarts示例_第6张图片

import Common from "@/util/echatrs/common";
import * as echarts from "echarts";
export default class BarLine extends Common {

    constructor(el, option) {
        super(el, option);
        this.init();

    }
    init() {
        this.myChart = this.$e.init(this.$el);
        this.setCharts();
        this.myChart.setOption(this.chartOption, true);
        window.addEventListener("resize", () => {
            this.myChart.resize();
        });
        this.myChart.on("click", (a) => {
            if (this.option.click) {
                this.option.click(a);
            }
        });
    }

    setCharts() {

        if (this.option.theme === "dark") {
            this.chartOption = {
                legend: {
                    itemHeight: 6,
                    itemWidth: 16,
                    x: "center", //居右显示
                    inactiveColor: "rgba(0,0,0,0.9)", // 图例关闭后的颜色
                    textStyle: {
                        fontSize: 14,
                        color: "#7E9CC1", // 图例的文字颜色
                        padding: [3, 0, 0, 0],
                    },
                    data: ["延迟完工项目数量", "延迟完工率"],
                },
                tooltip: {
                    trigger: "axis",
                    axisPointer: { // 鼠标移上去时,触发后的样式
                        type: "shadow"
                    },
                    padding: 0,
                    borderColor: "rgba(0, 0, 0, 0)",
                    borderWidth: 0,
                    formatter: function (obj) {
                        // console.log(obj);
                        var name = obj[0].name || obj[1].name;
                        var number = obj[0].value;
                        var rate = obj[1].value;
                        // const lineImg = "";
                        const darkImg = "";

                        // console.log(name, number, rate);
                        return "
" + "
" + " " + "" + name + "
" + "
" + "
" + "" + number + "项" + "延迟完工" + "
" + "
" + "" + rate + "%" + "延迟率" + "
" + "
" + "
"; } }, grid: { left: "3.5%", right: "2.5%", bottom: "21%", containLabel: false }, xAxis: { type: "category", data: this.option.xValue, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 rotate: 45, textStyle: { color: "#707793", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: "项目数量:个", nameTextStyle: { // name的样式 color: "#707793", fontSize: 14 }, splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "solid", width: 1 } }, axisLabel: { // y轴的文字样式 textStyle: { color: "#707793", fontSize: 14 }, } }, { type: "value", name: "延迟率:%", nameTextStyle: { color: "#707793", fontSize: 14 }, position: "right", splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "solid", width: 1 } }, axisLabel: { show: true, textStyle: { color: "#707793", fontSize: 14 }, } }, // { // type: "value", // gridIndex: 0, // min: 50, // max: 100, // splitNumber: 8, // splitLine: { // show: false // }, // axisLine: { // show: false // }, // axisTick: { // show: false // }, // axisLabel: { // show: false // }, // splitArea: { // show: true, // areaStyle: { // color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.05)"] // } // } // } ], series: [ { name: "延迟完工项目数量", type: "bar", color: "#1795ff", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barWidth: "14px", // 柱子的宽度 itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "#00C9FF" // 0% 处的颜色 }, { offset: 1, color: "#1991FF" // 100% 处的颜色 }], false), lineStyle: { width: 3 }, barBorderRadius: [2, 2, 0, 0], }, }, data: this.option.yCount }, { name: "延迟完工率", type: "line", color: "#F6AB00", barWidth: "14px", // 柱子的宽度 yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 showAllSymbol: true, //显示所有图形。 smooth: false, //平滑曲线显示 symbol: "circle", symbolSize: 5, //标记的大小 itemStyle: { normal: { lineStyle: { width: 1 } } }, data: this.option.yRate }, ] }; } else { this.chartOption = { legend: { itemHeight: 6, itemWidth: 16, x: "center", //居右显示 inactiveColor: "rgba(0,0,0,0.3)", // 图例关闭后的颜色 textStyle: { fontSize: 14, color: "#707793", // 图例的文字颜色 padding: [3, 0, 0, 0], }, data: ["延迟完工项目数量", "延迟完工率"], }, tooltip: { trigger: "axis", axisPointer: { // 鼠标移上去时,触发后的样式 type: "shadow" }, padding: 0, borderColor: "rgba(0, 0, 0, 0)", borderWidth: 0, formatter: function (obj) { // console.log(obj); var name = obj[0].name || obj[1].name; var number = obj[0].value; var rate = obj[1].value; const lineImg = ""; // const darkImg = ""; // console.log(name, number, rate); return "
" + "
" + " " + "" + name + "
" + "
" + "
" + "" + number + "项" + "延迟完工" + "
" + "
" + "" + rate + "%" + "延迟率" + "
" + "
" + "
"; } }, grid: { left: "3.5%", right: "2.5%", bottom: "21%", containLabel: false }, xAxis: { type: "category", data: this.option.xValue, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 rotate: 45, textStyle: { color: "#707793", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(0, 112, 107, 0.2)", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: "项目数量:个", nameTextStyle: { // name的样式 color: "#707793", fontSize: 14 }, splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 112, 107, 0.2)", type: "solid", width: 1 } }, axisLabel: { // y轴的文字样式 textStyle: { color: "#707793", fontSize: 14 }, } }, { type: "value", name: "延迟率:%", nameTextStyle: { color: "#707793", fontSize: 14 }, position: "right", splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 112, 107, 0.2)", type: "solid", width: 1 } }, axisLabel: { show: true, textStyle: { color: "#707793", fontSize: 14 }, } }, // { // type: "value", // gridIndex: 0, // min: 50, // max: 100, // splitNumber: 8, // splitLine: { // show: false // }, // axisLine: { // show: false // }, // axisTick: { // show: false // }, // axisLabel: { // show: false // }, // splitArea: { // show: true, // areaStyle: { // color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.05)"] // } // } // } ], series: [ { name: "延迟完工项目数量", type: "bar", color: "#009D85", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barWidth: "14px", // 柱子的宽度 itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "#00C29F" // 0% 处的颜色 }, { offset: 1, color: "#009D85" // 100% 处的颜色 }], false), lineStyle: { width: 3 }, barBorderRadius: [2, 2, 0, 0], } }, data: this.option.yCount }, { name: "延迟完工率", type: "line", color: "#F6AB00", barWidth: "14px", // 柱子的宽度 yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 showAllSymbol: true, //显示所有图形。 smooth: false, //平滑曲线显示 symbol: "circle", symbolSize: 5, //标记的大小 itemStyle: { normal: { lineStyle: { width: 1 } } }, data: this.option.yRate }, ] }; } } setField() { const colors = this.option.colors; const sourceData = this.option.data; const total = sourceData.reduce((num, item) => { num += item.value; return num; }, 0); // 内环间隔距离 const inSplitWidth = 3; // 为了实现内环间隔距离,需要额外插入的数值。200 只是个系数,值越大,单位间隔的距离越小。 const inSplitValue = Math.floor(total / (150 / inSplitWidth)); // 外环间隔比内环间隔大的值 const itemSplitWidth = 2; // 外环间隔距离 const outSplitWidth = inSplitWidth + itemSplitWidth; // 为了实现外环间隔距离,需要额外插入的数值。 const outSplitValue = Math.floor(total / (150 / outSplitWidth)); // 内环数据的总数 const valueTotal = total + inSplitValue * sourceData.length; function getTextAngle(currentAngle, angle) { currentAngle = currentAngle + angle; if (currentAngle <= 90) { return -currentAngle; } else if (currentAngle <= 180 && currentAngle > 90) { return 180 - currentAngle; } else if (currentAngle < 270 && currentAngle > 180) { return 180 - currentAngle; } else if (currentAngle < 360 && currentAngle >= 270) { return 360 - currentAngle; } } // 内环数据。在原数据的后面添加间隔数据(间隔块设置颜色透明) const valueData = sourceData.reduce((arr, item) => { const currentTotal = arr.reduce((total, item) => { total += item.value; return total; }, 0); const currentAngle = 360 * (currentTotal / valueTotal); const angle = 360 * (item.value / valueTotal) / 2; arr.push({ name: item.name, value: item.value, label: { lineHeight: 80, rotate: getTextAngle(currentAngle, angle) } }, { name: "", value: inSplitValue, itemStyle: { color: "transparent", opacity: 0 }, label: { show: false }, labelLine: { show: false } }); return arr; }, []); // 原数据需要减去的值(外环每块的数据都要比原数据少一点才能达到外环嵌在内环的效果) const itemReduced = outSplitValue - inSplitValue; // 外环数据 const outValueData = sourceData.reduce((arr, item) => { const currentTotal = arr.reduce((total, item) => { total += item.value; return total; }, 0); const currentAngle = 360 * (currentTotal / valueTotal); const angle = 360 * (item.value / valueTotal) / 2; arr.push({ name: item.name, value: item.value, label: { color: "#fff", position: "inside", align: "center", lineHeight: 10, // verticalAlign: 'top', rotate: getTextAngle(currentAngle, angle) } }, { name: "", value: outSplitValue, itemStyle: { color: "transparent", opacity: 0 }, label: { show: false, textStyle: { fontSize: 12, color: "#fff" } }, labelLine: { show: false } }); return arr; }, []); return { colors, total, valueData, itemReduced, valueTotal, outValueData }; } }

案例七:(立体柱状图) 

常用echarts示例_第7张图片

  setCharts() {






        const barWidth = 10
        this.chartOption = {

            grid: {
                left: "15%",
                right: "0%",
                bottom: "15%",
                containLabel: false
            },
            legend: {
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#A1D1EF", // 图例的文字颜色
                    padding: [0, 0, 0, 0],
                },
                selectedMode: false,
                data: ['老人数', '预警数'],
            },
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'shadow'
                },
                formatter: function (e) {
                    // console.log(e);
                    var str =
                        e[4].axisValue +
                        "
" + "" + "" + e[4].seriesName + " : " + e[4].value + "
" + "" + "" + e[5].seriesName + " : " + e[5].value; return str; } }, xAxis: { type: 'category', data: ['市区', '高邮市', '仪征市', '江都区', '宝应县' ], splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 textStyle: { color: "#A1D1EF", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(39, 166, 255, 0.5)", type: "solid", width: 1 } } }, yAxis: { type: "value", name: '单位:kw·h ', splitNumber: 5, nameTextStyle: { // name的样式 color: "#6699C1", align: 'left', padding: [0, 0, 0, -25] }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false }, splitLine: { lineStyle: { color: "#27A6FF", opacity: 0.3, type: "dashed", }, }, axisLabel: { textStyle: { color: "#A1D1EF", }, }, }, series: [ // (0)第一个柱子 中间的正方形 { type: "pictorialBar", // 象型柱状 symbol: "diamond", symbolSize: [barWidth, 5], // 调整大小 // symbolOffset: [-13, -3], // 图形相对于原本位置的偏移 symbolOffset: ["-55%", -3], // 图形相对于原本位置的偏移 symbolPosition: "end", z: 12, color: "#6ac1ff", data: [112, 23, 56, 6, 89], }, // (1)第二个柱子中间的正方形 { type: "pictorialBar", symbol: "diamond", symbolSize: [barWidth, 8], // symbolOffset: [13, -3], symbolOffset: ["55%", -3], symbolPosition: "end", z: 12, color: "#ffad96", data: [12, 213, 256, 16, 9], }, // (2)第一个柱子 底部的正方形 { type: "pictorialBar", symbol: "diamond", symbolSize: [barWidth, 5], // symbolOffset: [-13, 3], symbolOffset: ["-55%", 3], z: 12, color: "#6ac1ff", data: [112, 23, 56, 6, 89], }, // (3)第二个柱子 底部的正方形 { name: "", type: "pictorialBar", symbol: "diamond", symbolSize: [barWidth, 5], // symbolOffset: [13, 3], symbolOffset: ["55%", 3], color: "#ffad96", z: 12, data: [12, 213, 256, 16, 9], }, // (4)一个柱子, 下方有颜色填充的的柱子 { name: '老人数', type: "bar", barWidth: barWidth, barGap: "20%", // zlevel: 2, stack: "1", itemStyle: { opacity: 1, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [ { offset: 0.5, color: "#27a6ff", // color: '#2c61bc', }, { offset: 0.5, color: "#0f85d7", }, { offset: 1, color: "#1d90e1", }, ]), // barBorderRadius: 0, borderRadius: 0, }, // 是否在每个柱子显示 相应的值 label: { show: false, position: ["0", "-25"], color: "#005dd9", fontSize: 14, fontWeight: 'bold' }, data: [112, 23, 56, 6, 89], }, // (5)第二个柱子, 下方有颜色填充的的柱子 { name: '预警数', type: "bar", stack: "2", barWidth: barWidth, itemStyle: { opacity: 1, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [ { offset: 0.5, color: "#ff744c", }, { offset: 0.5, color: "#d2512c", }, { offset: 1, color: "#eb653e", }, ]), // barBorderRadius: 0, borderRadius: 0, }, // 是否在每个柱子显示 相应的值 label: { show: false, position: ["0", "-25"], color: "#06e6f6", fontSize: 14, fontWeight: 'bold' }, data: [12, 213, 256, 16, 9], }, ] } }

 案例八:(水平立体圆柱图)

常用echarts示例_第8张图片

 setCharts() {
        const y1 = [12, 23, 56, 88, 56]
        const y2 = [89, 56, 88, 32, 89]

        const y12 = [];

        for (let i = 0; i < y1.length; i++) {
            y12.push(y1[i] + y2[i]);
        }
        this.chartOption = {

            grid: {
                left: "15%",
                right: "8%",
                bottom: "15%",
                containLabel: false
            },
            legend: {
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#A1D1EF", // 图例的文字颜色
                    padding: [0, 0, 0, 0],
                },
                selectedMode: false,
                data: ['处理数', '预警数'],
            },
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'shadow'
                },
                formatter: function (e) {
                    // console.log(e);
                    var str =
                        e[2].axisValue +
                        "
" + "" + "" + e[4].seriesName + " : " + e[2].value + "
" + "" + "" + e[4].seriesName + " : " + e[4].value; return str; } }, xAxis: { type: 'value', splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 show: true, textStyle: { color: "#A1D1EF", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(39, 166, 255, 0.5)", type: "dashed", width: 1 } } }, yAxis: { type: "category", data: ['市区', '高邮市', '仪征市', '江都区', '宝应县' ], // name: '单位:kw·h ', // inverse: true, splitNumber: 5, nameTextStyle: { // name的样式 color: "#6699C1", align: 'left', padding: [0, 0, 0, -25] }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false }, splitLine: { lineStyle: { color: "#27A6FF", opacity: 0.3, type: "dashed", }, }, axisLabel: { textStyle: { color: "#A1D1EF", }, }, }, series: [{ // 圆柱的顶部 // "name": "", type: 'pictorialBar', stack: '顶部', symbolSize: [5, 12], symbolOffset: [0, 0], symbolPosition: 'end', z: 12, // "barWidth": "0", "label": { "normal": { "show": false, "position": "top", // "formatter": "{c}%" fontSize: 15, fontWeight: 'bold', color: '#34DCFF' } }, color: "#31fdfd", data: y1 }, // 圆柱的底部 { // name: '', type: 'pictorialBar', symbolSize: [5, 12], stack: '底部', symbolOffset: [0, 0], // "barWidth": "20", z: 12, "color": "#31fdfd", "data": y1 }, // 圆柱子主体 { type: 'bar', name: '处理数', //silent: true, stack: 'a', "barWidth": "12", // barGap: '10%', // Make series be overlap // barCateGoryGap: '10%', itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 0.7, [{ offset: 0, color: "#25b5b5" }, { offset: 1, color: "#25b5b5" } ]), opacity: .8 }, }, data: y1 }, { // 圆柱的顶部 // "name": "", stack: '顶部', type: 'pictorialBar', symbolSize: [5, 12], // symbolOffset: [0, 0], symbolPosition: 'end', z: 12, // "barWidth": "0", "label": { "normal": { "show": false, "position": "top", // "formatter": "{c}%" fontSize: 15, fontWeight: 'bold', color: '#34DCFF' } }, color: "#50b6fd", data: y12 }, // 圆柱的底部 // { // name: '', // stack: '底部', // type: 'pictorialBar', // symbolSize: [5, 12], // symbolOffset: [0, 0], // // "barWidth": "20", // z: 13, // "color": "pink", // "data": [2, 23, 20, 40, 272] // }, { type: 'bar', name: '预警数', //silent: true, "barWidth": "12", stack: 'a', itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 0.7, [{ offset: 0, color: "#3c8ac0" }, { offset: 1, color: "#3c8ac0" } ]), opacity: .8 }, }, data: y2 }, ] } }

案例九:(进度条渐变+自定义tooltip)

常用echarts示例_第9张图片

  setCharts() {

        if (this.option.theme === "dark") {
            this.chartOption = {
                legend: {
                    itemHeight: 6,
                    itemWidth: 16,
                    x: "right", //居右显示
                    inactiveColor: "rgba(0,0,0,0.9)", // 图例关闭后的颜色
                    textStyle: {
                        fontSize: 14,
                        color: "#707793", // 图例的文字颜色
                        padding: [3, 0, 0, 0],
                    },
                    data: ["项目数量", "延迟完工", "提前完工", "在建"],
                },
                tooltip: {
                    trigger: "axis",
                    axisPointer: { // 鼠标移上去时,触发后的样式
                        type: "shadow"
                    },
                    padding: 0,
                    borderColor: "rgba(0, 0, 0, 0)",
                    borderWidth: 0,
                    formatter: function (obj) {

                        var name = obj[0].name || obj[1].name || obj[2].name || obj[3].name;
                        var projectCount = obj.find(i => i.seriesName === "项目数量") ? obj.find(i => i.seriesName === "项目数量").value : "-";
                        var delayCount = obj.find(i => i.seriesName === "延迟完工") ? obj.find(i => i.seriesName === "延迟完工").value : "-";
                        var advanceCount = obj.find(i => i.seriesName === "提前完工") ? obj.find(i => i.seriesName === "提前完工").value : "-";
                        var constructionCount = obj.find(i => i.seriesName === "在建") ? obj.find(i => i.seriesName === "在建").value : "-";
                        // var number = obj[0].value;
                        // var rate = obj[1].value;
                        // const lineImg = "";
                        const darkImg = "";

                        return "
" + "
" + " " + "" + name + "
" + "
" + "
" + "
" + "" + projectCount + "项" + "项目数量" + "
" + "
" + "" + delayCount + "项" + "延迟完工" + "
" + "
" + "
" + "
" + "" + advanceCount + "项" + "提前完工" + "
" + "
" + "" + constructionCount + "项" + "在建" + "
" + "
" + "
" + "
"; } }, grid: { left: "8%", right: "2.5%", bottom: "7%", containLabel: false }, xAxis: { type: "category", data: this.option.xValue, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 textStyle: { color: "#7E9CC1", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: "项目数量:个", nameTextStyle: { // name的样式 color: "#707793", fontSize: 14 }, splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "solid", width: 1 } }, axisLabel: { // y轴的文字样式 textStyle: { color: "#7E9CC1", fontSize: 14 }, } }, ], series: [ { name: "项目数量", type: "bar", color: "#009D85", nameStyle: { width: 100 }, barGap: 1, // 柱子之间的间距 yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(0, 201, 255, 0)" // 0% 处的颜色 }, { offset: 1, color: "#00C9FF" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yProjectCount }, { name: "延迟完工", type: "bar", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(0, 255, 254, 0)" // 0% 处的颜色 }, { offset: 1, color: "#00FFFE" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yDelayCount }, { name: "提前完工", type: "bar", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(218, 51, 218, 0) " // 0% 处的颜色 }, { offset: 1, color: "#DA33DA" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yAdvanceCount }, { name: "在建", type: "bar", color: "#009D85", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(255, 141, 80, 0) " // 0% 处的颜色 }, { offset: 1, color: "#FF8D50" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yConstructionCount }, ] }; } else { this.chartOption = { legend: { itemHeight: 6, itemWidth: 16, x: "right", //居右显示 inactiveColor: "rgba(0,0,0,0.3)", // 图例关闭后的颜色 textStyle: { fontSize: 14, color: "#707793", // 图例的文字颜色 padding: [3, 0, 0, 0], }, data: ["项目数量", "延迟完工", "提前完工", "在建"], }, tooltip: { trigger: "axis", axisPointer: { // 鼠标移上去时,触发后的样式 type: "shadow" }, padding: 0, borderColor: "rgba(0, 0, 0, 0)", borderWidth: 0, formatter: function (obj) { var name = obj[0].name || obj[1].name || obj[2].name || obj[3].name; var projectCount = obj.find(i => i.seriesName === "项目数量") ? obj.find(i => i.seriesName === "项目数量").value : "-"; var delayCount = obj.find(i => i.seriesName === "延迟完工") ? obj.find(i => i.seriesName === "延迟完工").value : "-"; var advanceCount = obj.find(i => i.seriesName === "提前完工") ? obj.find(i => i.seriesName === "提前完工").value : "-"; var constructionCount = obj.find(i => i.seriesName === "在建") ? obj.find(i => i.seriesName === "在建").value : "-"; // var number = obj[0].value; // var rate = obj[1].value; const lineImg = ""; return "
" + "
" + " " + "" + name + "
" + "
" + "
" + "
" + "" + projectCount + "项" + "项目数量" + "
" + "
" + "" + delayCount + "项" + "延迟完工" + "
" + "
" + "
" + "
" + "" + advanceCount + "项" + "提前完工" + "
" + "
" + "" + constructionCount + "项" + "在建" + "
" + "
" + "
" + "
"; } }, grid: { left: "8%", right: "2.5%", bottom: "7%", containLabel: false }, xAxis: { type: "category", data: this.option.xValue, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 textStyle: { color: "#707793", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "rgba(0, 112, 107, 0.2)", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: "项目数量:个", nameTextStyle: { // name的样式 color: "#707793", fontSize: 14 }, splitLine: {//分割线配置 show: false, }, axisTick: { // 取消刻度线上的小刻度 show: true }, axisLine: { // 取消整个刻度线 show: true, lineStyle: { color: "rgba(0, 112, 107, 0.2)", type: "solid", width: 1 } }, axisLabel: { // y轴的文字样式 textStyle: { color: "#707793", fontSize: 14 }, } }, ], series: [ { name: "项目数量", type: "bar", color: "#009D85", nameStyle: { width: 100 }, barGap: 1, // 柱子之间的间距 yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(0, 157, 133, 0)" // 0% 处的颜色 }, { offset: 1, color: "#009d85" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yProjectCount }, { name: "延迟完工", type: "bar", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(0, 136, 255, 0)" // 0% 处的颜色 }, { offset: 1, color: "#0088FF" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yDelayCount }, { name: "提前完工", type: "bar", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(218, 51, 218, 0) " // 0% 处的颜色 }, { offset: 1, color: "#DA33DA" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yAdvanceCount }, { name: "在建", type: "bar", color: "#009D85", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(255, 141, 80, 0) " // 0% 处的颜色 }, { offset: 1, color: "#FF8D50" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yConstructionCount }, ] }; } }

案例十(自定义折线图转折点)

常用echarts示例_第10张图片

 setCharts() {

        const data1 = JSON.parse(JSON.stringify(this.option.yData1))
        const data2 = JSON.parse(JSON.stringify(this.option.yData2))
        const maxData1 = (data1.sort((a, b) => Number(b) - Number(a)))[0]
        const maxData2 = (data2.sort((a, b) => Number(b) - Number(a)))[0]

        const maxNum = Number(maxData1) > Number(maxData2) ? maxData1 : maxData2
        // 获取最大值:目的是实现折线图下面的 柱形
        const newArr = []
        for (var i = 0; i < 12; i++) {
            newArr.push(maxNum)
        }


        const blueDot = 'image://'
        const yellowDot = 'image://'
        this.chartOption = {
            legend: {
                orient: 'vertical',// 竖直排列
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "right", //居右显示
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#A1D1EF", // 图例的文字颜色
                    padding: [0, 0, 0, 0],
                },
                top: '0%',
                selectedMode: false,
                data: this.option.leged,
                icon: "stack", // 将折线的图例改成矩形
            },
            tooltip: {
                trigger: "axis",
                axisPointer: { // 鼠标移上去时,触发后的样式
                    type: "shadow"
                },
                formatter: function (e) {
                    const arr = e.filter(i => i.componentSubType == 'line')
                    if (arr.length === 2) {
                        var str =
                            arr[0].axisValue +
                            "
" + "" + "" + arr[0].seriesName + " : " + arr[0].value + "
" + "" + "" + arr[1].seriesName + " : " + arr[1].value; return str; } if (arr.length === 1) { var stt = arr[0].axisValue + "
" + "" + "" + arr[0].seriesName + " : " + arr[0].value; return stt; } } }, grid: { left: "0%", right: "0%", bottom: "3%", top: '35%', containLabel: true }, xAxis: { type: "category", // data: yearList, data: this.option.xData, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 interval: 0, textStyle: { color: "#A1D1EF", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: false, lineStyle: { color: "rgba(39, 166, 255, 0.5)", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: this.option.unit, // splitNumber:5 , // y轴坐标刻度分隔 nameTextStyle: { // name的样式 color: "#6699C1", align: 'left', padding: [0, 0, 0, -25] }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false }, splitLine: { show: false, lineStyle: { color: "#27A6FF", opacity: 0.3, type: "dashed", }, }, axisLabel: { textStyle: { color: "#A1D1EF", }, }, }, ], series: [ { type: "line", name: this.option.leged[0], smooth: false, // 平滑的折线 showAllSymbol: true, //显示所有图形。 symbol: yellowDot, symbolSize: 12, //标记的大小 itemStyle: { normal: { color: "#ff744c", //改变折线点的颜色 lineStyle: { color: "#ff744c", //改变折线颜色 type: "solid" } } }, toolbox: { show: false, }, data: this.option.yData1, }, { type: "line", name: this.option.leged[1], smooth: false, // 平滑的折线 showAllSymbol: true, //显示所有图形。 symbol: blueDot, symbolSize: 12, //标记的大小 itemStyle: { normal: { color: "#27A6FF", //改变折线点的颜色 lineStyle: { color: "#27A6FF", //改变折线颜色 type: "solid" } } }, toolbox: { show: false, }, data: this.option.yData2, }, { name: '柱子', type: 'bar', barGap: '-100%', barWidth: 28, label: { normal: { color: '#00f3fb' } }, itemStyle: { normal: { color: '#05243c', } }, z: -12, data: newArr } ], }; }

 案例十一(自定义柱状图顶部的圆形)

常用echarts示例_第11张图片

  setCharts() {
        const yellowDot = 'image://'
        const blueDot = 'image://'
        this.chartOption = {
            legend: {
                itemHeight: 6,
                itemWidth: 16,
                x: "center", //居右显示
                inactiveColor: "rgba(0,0,0,0.9)", // 图例关闭后的颜色
                icon: "stack", // 将折线的图例改成矩形
                textStyle: {
                    fontSize: 14,
                    color: "#A1D1EF", // 图例的文字颜色
                    padding: [3, 0, 0, 0],
                },
                selectedMode: false,
                data: this.option.leged
            },
            tooltip: {
                trigger: "axis",
                axisPointer: { // 鼠标移上去时,触发后的样式
                    type: "shadow"
                },
                formatter: function (e) {
                    if (e.length === 4) {
                        var str =
                            e[0].axisValue +
                            "
" + "" + "" + e[0].seriesName + " : " + e[0].value + "
" + "" + "" + e[2].seriesName + " : " + e[2].value; return str; } if (e.length === 2) { var stt = e[0].axisValue + "
" + "" + "" + e[0].seriesName + " : " + e[0].value ; return stt; } } }, grid: { left: "2%", right: "2.5%", bottom: "7%", containLabel: true }, xAxis: { type: "category", data: this.option.xData, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 interval: 0, // x轴坐标完全展示 textStyle: { color: "#A1D1EF", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "#27A6FF", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: this.option.unit, nameTextStyle: { // name的样式 color: "#6699C1", fontSize: 14 }, splitLine: {//分割线配置 show: true, lineStyle: { color: "#09304d", type: "dashed", width: 1 } }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false, lineStyle: { color: "rgba(0, 201, 255, 0.2)", type: "dashed", width: 1 } }, axisLabel: { // y轴的文字样式 textStyle: { color: "#A1D1EF", fontSize: 12 }, } }, ], series: [ { name: this.option.leged[0], type: "bar", nameStyle: { width: 100 }, color: '#27a6ff', barGap: 3, // 柱子之间的间距 yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 2, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(39, 166, 255, 0)" // 0% 处的颜色 }, { offset: 1, color: "#27A6FF" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yData1 }, // 头部的小球 { name: this.option.leged[0], type: 'pictorialBar', symbol: blueDot, // symbol: "diamond", symbolSize: [21, 21], symbolOffset: [-8, -10], symbolPosition: "end", z: 12, data: this.option.yData1 }, { name: this.option.leged[1], type: "bar", color: "#ff744c", nameStyle: { width: 100 }, barGap: 3, // 柱子之间的间距 yAxisIndex: 0, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 barMinWidth: "4px", // 柱子的宽度 barWidth: 2, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ { offset: 0, color: "rgba(255, 116, 76, 0)" // 0% 处的颜色 }, { offset: 1, color: "#FF744C" // 100% 处的颜色 } ], false), barBorderRadius: [30, 30, 0, 0], } }, data: this.option.yData2 }, // 头部的小球 { name: this.option.leged[1], type: 'pictorialBar', symbol: yellowDot, // symbol: "diamond", symbolSize: [34, 34], symbolOffset: [8, -15], symbolPosition: "end", z: 12, data: this.option.yData2 }, ] }; }

案例十二
常用echarts示例_第12张图片

   setCharts() {


        // 黄色部分 堆叠的数据
        const splitBar2Value = [];

        for (let i = 0; i < this.option.barData2.length; i++) {
            splitBar2Value.push(this.option.barData1[i] + this.option.barData2[i]);
        }
        this.chartOption = {
            legend: {
                icon: "stack", // 将折线的图例改成矩形
                itemHeight: 6,
                itemWidth: 16,
                x: "center", //居右显示
                top: '8%',
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#B5ECF9", // 图例的文字颜色
                    padding: [0, 0, 0, 0],
                },
                selectedMode: false, // 点击图例不可以取消
                data: this.option.legend,
            },
            tooltip: {
                trigger: "axis",
                axisPointer: { // 鼠标移上去时,触发后的样式
                    type: "shadow"
                },
                formatter: function (e) {
                    console.log(e);
                    const showTool = e.filter(i => (i.componentSubType == 'bar' || i.componentSubType == 'line'))
                    console.log(showTool, '789');
                    if (showTool.length === 3) {
                        const str =
                            showTool[0].axisValue +
                            "
" + "" + "" + showTool[0].seriesName + " : " + showTool[0].value + "
" + "" + "" + showTool[1].seriesName + " : " + showTool[1].value + "
" + "" + "" + showTool[2].seriesName + " : " + showTool[2].value; return str; } if (showTool.length === 2) { const stt = showTool[0].axisValue + "
" + "" + "" + showTool[0].seriesName + " : " + showTool[0].value + "
" + "" + "" + showTool[1].seriesName + " : " + showTool[1].value; return stt; } if (showTool.length === 1) { const stg = showTool[0].axisValue + "
" + "" + "" + showTool[0].seriesName + " : " + showTool[0].value; return stg; } } }, grid: { left: "3.5%", right: "2%", bottom: "3%", top: '30%', containLabel: true }, xAxis: { type: "category", // data: yearList, data: this.option.xData, splitLine: {//分割线配置 show: false }, axisLabel: { // x轴线文字的样式 textStyle: { color: "#59A6B7", fontSize: 12 }, }, axisTick: { show: false }, axisLine: {//x轴线的颜色以及宽度 show: true, lineStyle: { color: "#053c45", type: "solid", width: 1 } } }, yAxis: [ { type: "value", name: this.option.unit1, nameTextStyle: { // name的样式 color: "#B5ECF9" }, splitLine: {//分割线配置 show: false, lineStyle: { color: "#3AB2B4", type: "solid", width: 0 } }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false }, axisLabel: { // y轴的文字样式 textStyle: { color: "#59A6B7" }, } }, { type: "value", name: this.option.unit2, nameTextStyle: { color: "#B5ECF9", padding: [0, 10, 0, 0] }, position: "right", splitLine: {//分割线配置 show: false, lineStyle: { color: "rgba(0, 112, 107, 0.1)" } }, axisTick: { // 取消刻度线上的小刻度 show: false }, axisLine: { // 取消整个刻度线 show: false }, axisLabel: { show: true, textStyle: { color: "#59A6B7" }, } }, { type: "value", gridIndex: 0, min: 50, max: 100, splitNumber: 8, splitLine: { show: false }, axisLine: { show: false, }, axisTick: { show: false }, axisLabel: { show: false }, splitArea: { show: true, areaStyle: { color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.02)"] } } } ], series: [ { name: this.option.legend[0], type: "bar", color: "#0CD5F0", // stack设置柱状图堆叠,stack后面要跟同样的名字 stack: "Search Engine", nameStyle: { width: 100 }, yAxisIndex: 0, //使用的 y 轴的 左侧的单位,在单个图表实例中存在多个 y轴的时候有用 barWidth: "14px", // 柱子的宽度 itemStyle: { normal: { lineStyle: { width: 3 } } }, data: this.option.barData1 }, { // 分隔 name: this.option.legend[0], type: "pictorialBar", itemStyle: { // 格子之间的距离的颜色 normal: { color: "#011419" } }, stack: "a", symbolRepeat: "fixed", symbolMargin: 2,// 每个小格子的上下之间距离 symbol: "rect", symbolClip: true, symbolSize: [14, 2],//每个分割的格子的大小 symbolPosition: "start", // symbolOffset: [1, 1], data: this.option.barData1, width: 8, zlevel: 1 }, // yAxisIndex: 0, 因为处理数和预警数在一起 所以将这两个的值设置为同一个,这样 处理数和预警数会同时使用左侧的 y轴的坐标 { name: this.option.legend[1], type: "bar", // stack设置柱状图堆叠,stack后面要跟同样的名字 stack: "Search Engine", color: "#FF850B", barWidth: "12px", // 柱子的宽度 yAxisIndex: 0, //使用的 y 轴的 左侧的单位,在单个图表实例中存在多个 y轴的时候有用 showAllSymbol: true, //显示所有图形。 itemStyle: { normal: { barBorderRadius: [2, 2, 2, 2], lineStyle: { width: 3 } } }, data: this.option.barData2 }, { // 分隔 type: "pictorialBar", itemStyle: { // 格子之间的距离的颜色 normal: { color: "#011419" } }, stack: "a", symbolRepeat: "fixed", symbolMargin: 2,// 每个小格子的上下之间距离 symbol: "rect", symbolClip: true, symbolSize: [14, 2], //每个分割的格子的大小 symbolPosition: "end", // symbolOffset: [1, 1], data: splitBar2Value, width: 8, zlevel: 1 }, { name: this.option.legend[2], type: "line", color: "#F54628", yAxisIndex: 1, //使用的 y 轴的右侧的单位,在单个图表实例中存在多个 y轴的时候有用 showAllSymbol: true, //显示所有图形。 smooth: false, //平滑曲线显示 symbol: "circle", symbolSize: 4, //标记的大小 itemStyle: { normal: { lineStyle: { width: 1 } } }, z: 4, data: this.option.lineData }, ] }; }

案例十三(饼图)

常用echarts示例_第13张图片

 setCharts() {
        const dataList = [
            {
                value: 75,
                show: true,
                name: '生物质烘干',
                itemStyle: {
                    normal: {
                        borderWidth: 10,
                        color: 'rgba(255, 255, 102, 1)',
                        borderColor: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
                            {
                                offset: 0,
                                color: '#303c27'
                            },
                            {
                                offset: 0.5,
                                color: 'rgba(255, 255, 102, 1)'
                            },
                            {
                                offset: 1,
                                color: '#303c27'
                            }
                        ])
                    }
                }
            },
            // 圆环之间的间隔
            {
                value: 20,
                show: false,
                name: '',
                itemStyle: {
                    normal: {
                        color: 'transparent'
                    }
                }
            },
            {
                value: 90,
                show: true,
                name: '空气源热泵烘干',
                itemStyle: {
                    normal: {
                        borderWidth: 10,
                        color: 'rgba(24, 248, 195, 1)',
                        borderColor: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
                            {
                                offset: 0,
                                color: '#0c574a'
                            },
                            {
                                offset: 0.5,
                                color: 'rgba(24, 248, 195, 1)'
                            },
                            {
                                offset: 1,
                                color: '#0c574a'
                            }
                        ])
                    }
                }
            },
            // 圆环之间的间隔
            {
                value: 20,
                show: false,
                name: '',
                itemStyle: {
                    normal: {
                        color: 'transparent'
                    }
                }
            },
            {
                value: 130,
                show: true,
                name: '直热电烘',
                itemStyle: {
                    normal: {
                        borderWidth: 10,
                        color: 'rgba(12, 213, 240, 1)',
                        borderColor: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
                            {
                                offset: 0,
                                color: '#044a54'
                            },
                            {
                                offset: 0.5,
                                color: 'rgba(12, 213, 240, 1)'
                            },
                            {
                                offset: 1,
                                color: '#044a54'
                            }
                        ])
                    }
                }
            },
            // 圆环之间的间隔
            {
                value: 20,
                show: false,
                name: '',
                itemStyle: {
                    normal: {
                        color: 'transparent'
                    }
                }
            },
        ]




        this.chartOption = {
            // title: this.option.title,
            "title": {
                "text": "5000",
                "subtext": "年度电烘干总\n容量(kW)",
                x: "center",
                y: '30%',
                textStyle: {
                    color: '#fff',
                    fontSize: '28'
                },
                subtextStyle: {
                    color: '#B5ECF9',
                    fontSize: '14',

                },
            },

            series: [
                {
                    name: '',
                    type: 'pie',
                    clockWise: false,
                    startAngle: '90',
                    center: ['50%', '50%'],
                    radius: ['60%', '61%'],
                    hoverAnimation: false,
                    itemStyle: {
                        normal: {
                            label: {
                                show: true,
                                position: 'outside',
                                color: '#fff',
                                formatter: function (params: any) {
                                    let percent: number | any = 0;
                                    let total = 0;
                                    for (let i = 0; i < dataList.length; i++) {
                                        total += dataList[i].value;
                                    }
                                    percent = ((params.value / total) * 100).toFixed(0);
                                    if (params.name !== '') {
                                        return ' {title|' + params.name + '}' + '\n{white|' + params.value + '}' + '\n{white|' + '占比' + percent + '%}';
                                    } else {
                                        return '';
                                    }
                                },
                                rich: {
                                    white: {
                                        color: '#ddd',
                                        align: 'left',
                                        padding: [3, 0]
                                    },
                                    title: {
                                        color: '#B5ECF9',
                                        align: 'left',
                                    }
                                }
                            },
                            labelLine: {
                                length: 10,
                                length2: 20,
                                show: true,
                            }
                        }
                    },
                    data: dataList,
                    animationType: 'scale',
                    animationEasing: 'elasticOut',
                    animationDelay: function (idx) {
                        return idx * 50;
                    }
                },
                // {
                //     name: '',
                //     type: 'pie',
                //     center: ['50%', '50%'],
                //     radius: ['49%', '49%'],
                //     itemStyle: {
                //         color: 'transparant'
                //     },
                //     startAngle: '90',
                //     data: [{
                //         value: total,
                //         name: '',
                //         label: {
                //             normal: {
                //                 show: true,
                //                 formatter: '{c|{c}} {b|条记录}',
                //                 rich: {
                //                     c: {
                //                         color: 'rgb(98,137,169)',
                //                         fontSize: 50,
                //                         fontWeight: 'bold',
                //                         lineHeight: 5
                //                     },
                //                     b: {
                //                         color: 'rgb(98,137,169)',
                //                         fontSize: 40,
                //                         lineHeight: 5
                //                     }
                //                 },
                //                 textStyle: {
                //                     fontSize: 28,
                //                     fontWeight: 'bold'
                //                 },
                //                 position: 'center'
                //             }
                //         }
                //     }]
                // }
            ]
        };
    }

案例十四:(折线图设置markLine和自定义的markPoint)

常用echarts示例_第14张图片

  setCharts() {



        const orangePoint = 'image://'
        const bluePoint = 'image://'
        const newArrLine1: any[] = [];
        (this.option.lineData1).map(function (val: any) {
            newArrLine1.push(val);
        })
        // 根据y轴的最大值的索引,找到x轴对应的值
        const maxLineData1Index = this.option.lineData1.indexOf((newArrLine1).sort((a: number, b: number) => Number(b) - Number(a))[0])


        const newArrLine2: any[] = [];
        // 根据y轴的最大值的索引,找到x轴对应的值
        (this.option.lineData2).map(function (val: any) {
            newArrLine2.push(val);
        })

        const maxLineData2Index = this.option.lineData2.indexOf((newArrLine2).sort((a: number, b: number) => Number(b) - Number(a))[0])
        this.chartOption = {
            legend: {
                icon: "stack", // 将折线的图例改成矩形
                itemHeight: 6, // 图例的高度
                itemWidth: 16, // 图例的宽度
                x: "center", //居右显示
                y: '10%',
                inactiveColor: "rgba(0,0,0,0.3)",// 图例关闭后的颜色
                textStyle: {
                    fontSize: 12,
                    color: "#B5ECF9", // 图例的文字颜色
                    padding: [30, 0, 0, 0],
                },
                selectedMode: false, // 点击图例不可以取消
                data: this.option.legend,
            },
            tooltip: {
                trigger: "axis",

            },
            grid: {
                left: "0%",
                right: "0%",
                bottom: "3%",
                containLabel: true
            },
            xAxis: {
                type: "category",
                // data: yearList,
                data: this.option.xData,
                splitLine: {//分割线配置
                    show: false
                },
                axisLabel: {  // x轴线文字的样式
                    textStyle: {
                        color: "#59A6B7",
                        fontSize: 12
                    },
                },
                axisTick: {
                    show: false
                },
                axisLine: {//x轴线的颜色以及宽度
                    show: true,
                    lineStyle: {
                        color: "#055f6c",
                        type: "solid",
                        width: 1
                    }
                }
            },
            yAxis: [
                {
                    type: "value",
                    name: this.option.unit1,
                    splitNumber: 5,
                    nameTextStyle: { // name的样式
                        color: "#B5ECF9"
                    },

                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine: { // 取消整个刻度线
                        show: false
                    },

                    splitLine: {
                        show: false,
                        lineStyle: {
                            color: "#59A6B7",
                            opacity: 0.3,
                            type: "dashed",
                        },
                    },
                    axisLabel: {
                        textStyle: {
                            color: "#59A6B7",
                        },
                    },
                },
                {
                    type: "value",
                    name: this.option.unit2,
                    splitNumber: 5,
                    nameTextStyle: { // name的样式
                        color: "#B5ECF9",
                        padding: [0, 10, 0, -10]
                    },

                    axisTick: { // 取消刻度线上的小刻度
                        show: false
                    },
                    axisLine: { // 取消整个刻度线
                        show: false
                    },

                    splitLine: {
                        show: false,
                        lineStyle: {
                            color: "#3AB2B4",
                            opacity: 0.3,
                            type: "solid",
                        },
                    },
                    axisLabel: {
                        textStyle: {
                            color: "#59A6B7",
                        },
                    },
                },
                {
                    type: "value",
                    gridIndex: 0,
                    min: 50,
                    max: 100,
                    splitNumber: 8,
                    splitLine: {
                        show: true,
                        lineStyle: {
                            color: "#3AB2B4",
                            opacity: 0.3,
                            type: "dashed",
                        },
                    },
                    axisLine: {
                        show: false
                    },
                    axisTick: {
                        show: false
                    },
                    axisLabel: {
                        show: false
                    },
                    splitArea: {
                        show: false,
                        areaStyle: {
                            color: ["rgba(250,250,250,0.0)", "rgba(250,250,250,0.05)"]
                        }
                    }
                }

            ],
            series: [
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name: this.option.legend[0],
                    smooth: true, // 平滑的折线
                    itemStyle: {
                        normal: {
                            color: "#ff9f48", //改变折线点的颜色
                            lineStyle: {
                                color: "#ff9f48", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: {
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(255, 159, 72, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(255, 159, 72, 0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: this.option.lineData1,
                    yAxisIndex: 0,
                    // 标注最大点
                    markPoint: {
                        symbol: orangePoint,
                        symbolSize: 14,
                        label: {
                            show: true,
                            normal: {
                                offset: [0, 5],
                                position: 'top',
                                textStyle: {
                                    color: '#ff850b'
                                }
                            }
                        },
                        data: [
                            {
                                type: 'max',
                                name: '最大值',
                            },
                        ]
                    },
                    markLine: {
                        lineStyle: {
                            normal: {
                                type: 'dashed',
                                color: '#dc9247'
                            }
                        },
                        symbol: 'circle',
                        symbolSize: 0,
                        animationDuration: 1000,
                        label: {
                            show: false,
                            position: 'middle',
                            formatter: '{b}:{c}'
                        },
                        data: [
                            { xAxis: this.option.xData[maxLineData1Index] }
                            // { type: 'min', name: '平均值', valueIndex: 0 },
                            // { type: 'max', name: '平均值', valueIndex: 1 }
                            // { xAxis: 170 }
                        ]
                    },
                },
                {
                    type: "line",
                    symbol: "none", // 不展示折线的圆点
                    name: this.option.legend[1],
                    smooth: true, // 平滑的折线
                    yAxisIndex: 1,
                    itemStyle: {
                        normal: {
                            color: "#4fe2cf", //改变折线点的颜色
                            lineStyle: {
                                color: "#4fe2cf", //改变折线颜色
                                type: "solid"
                            }
                        }
                    },
                    areaStyle: { // 折线下的区域颜色
                        //折线图颜色半透明
                        color: {
                            type: "linear",
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            colorStops: [{
                                offset: 0, color: "rgba(79, 226, 207, 0.5)" // 0% 处的颜色
                            }, {
                                offset: 1, color: "rgba(79, 226, 207,0)" // 100% 处的颜色
                            }],
                            global: false // 缺省为 false
                        }
                    },
                    toolbox: {
                        show: false,
                    },
                    data: this.option.lineData2,
                    // 标注最大点
                    markPoint: {
                        symbol: bluePoint,
                        symbolSize: 14,
                        label: {
                            show: true,
                            normal: {
                                offset: [0, 5],
                                position: 'top',
                                textStyle: {
                                    color: '#0cd5f0'
                                }
                            }
                        },
                        data: [
                            {
                                type: 'max',
                                name: '最大值',
                            },
                        ]
                    },
                    markLine: {
                        lineStyle: {
                            normal: {
                                type: 'dashed',
                                color: '#0cd5f0'
                            }
                        },
                        animationDuration: 1000,
                        symbol: 'circle',
                        symbolSize: 0,
                        label: {
                            show: false,
                            position: 'middle',
                            formatter: '{b}:{c}'
                        },
                        data: [
                            // { type: 'max', name: '平均值', valueIndex: 1 },
                            // { type: 'max', name: '平均值', valueIndex: 1 }
                            { xAxis: this.option.xData[maxLineData2Index] }
                        ]
                    },
                },


            ],
        };
    }

 

你可能感兴趣的:(element,echarts,echarts,javascript,ecmascript)