一篇文章带你搞定所有Echarts可视化图表

前言

可视化图表种类如此之多,什么场景下应该用什么图表展示,是一个让人头秃的难题。本篇文章带你从ECharts安装使用到配置各种样式的ECharts图表。

ECharts官网

Apache EChartsApache ECharts,一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。icon-default.png?t=N7T8https://echarts.apache.org/zh/index.html

1. 安装Echarts

原生JS项目中安装ECharts

<script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.4.3/echarts.min.js"></script>

Vue项目安装ECharts 

npm install echarts --save

2. 使用Echarts创建图表

// 配置图表数据和样式信息
let option = {
    //…………
}
// 调用ECharts的init方法
let myChart = echarts.init(
    document.getElementById("echartsId")
);
// 通过setOption渲染出图表
myChart.setOption(option);

3. 监听窗口尺寸变化调整ECharts图表大小,实现ECharts尺寸自适应

// 为窗口加上宽度变化事件,当宽高发生改变时,调用echarts的resize()方法,调整图表尺寸
window.addEventListener('resize', function () {
    myChart.resize();
})

4. 炫酷Echarts代码示例

这里给大家介绍4个我常用的ECharts素材网站,找到option中的样式直接copy代码即可。 

PPChart - 让图表更简单让图表更简单。PPChart 提供 Echarts 收录、图表制作等服务icon-default.png?t=N7T8https://ppchart.com/#/

echarts图表集ECharts图表集,EChartsDemo集,echarts gallery,Make A Pie,分享你的可视化作品isqqw.comicon-default.png?t=N7T8https://www.isqqw.com/

series-bar柱状图 - makeapie echarts社区图表可视化案例series-bar柱状图分类,makeapie echarts图表可视化案例, 分享你的可视化作品icon-default.png?t=N7T8https://www.makeapie.cn/echarts_category/series-bar

chart.top - 让图表更简单-echarts图集demo让图表更简单。chart.top 提供 Echarts 收录、图表制作等服务icon-default.png?t=N7T8http://chart.365api.cn/#/

4.1 柱状图
4.1.1 柱状图-1

代码: 

let xLabel = [
  "市区",
  "市南",
  "市北",
  "万州",
  "城口",
  "秀山",
  "川东",
  "綦南",
  "武隆",
];
option = {
  tooltip: {},
  backgroundColor: "#0f375f",
  animation: false,
  grid: {
    top: "25%",
    bottom: "10%", //也可设置left和right设置距离来控制图表的大小
  },
  xAxis: {
    data: xLabel,
    axisLine: {
      show: true, //隐藏X轴轴线
      lineStyle: {
        color: "#11417a",
      },
    },
    axisTick: {
      show: false, //隐藏X轴刻度
    },
    axisLabel: {
      show: true,
      margin: 14,
      fontSize: 14,
      textStyle: {
        color: "#A3C0DF", //X轴文字颜色
      },
    },
  },
  yAxis: [
    {
      type: "value",
      gridIndex: 0,
      min: 0,
      max: 100,
      interval: 25,
      // splitNumber: 4,
      splitLine: {
        show: true,
        lineStyle: {
          color: "#113763",
          width: 1,
        },
      },
      axisTick: {
        show: false,
      },
      axisLine: {
        show: true,
        lineStyle: {
          color: "#11417a",
        },
      },
      axisLabel: {
        show: true,
        margin: 14,
        fontSize: 14,
        textStyle: {
          color: "#A3C0DF", //X轴文字颜色
        },
      },
    },
  ],
  series: [
    {
      // 值
      name: "采集覆盖率情况",
      type: "bar",
      barWidth: 30,
      itemStyle: {
        normal: {
          color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
            {
              offset: 0,
              color: "rgba(249,255,59,1)",
            },
            {
              offset: 1,
              color: "rgba(15,38,35,0.2)",
            },
          ]),
        },
      },
      data: [88.6, 88.9, 89, 88.8, 88.8, 20, 20, 20, 20],
      z: 10,
      zlevel: 2,
      label: {
        show: true,
        position: "top",
        distance: 10,
        fontSize: 16,
        fontFamily: "DIN",
        color: "#ffffff",
        zlevel: 4,
        z: 10,
        formatter: "{c}%",
      },
    },
    {
      // 值分隔
      type: "pictorialBar",
      itemStyle: {
        normal: {
          color: "#0F375F",
        },
      },
      symbolRepeat: "fixed",
      symbolMargin: 3,
      symbol: "rect",
      symbolClip: true,
      symbolSize: [30, 3],
      symbolPosition: "start",
      symbolOffset: [0, -1],
      // symbolBoundingData: this.total,
      data: [88.6, 88.9, 89, 88.8, 88.8, 20, 20, 20, 20],
      width: 25,
      z: 0,
      zlevel: 3,
    },
    {
      //辅助背景图形
      name: "背景条",
      type: "bar", //pictorialBar
      barWidth: "30",
      barGap: "-100%",
      itemStyle: {
        normal: {
          borderWidth: 0,
          color: "rgba(146,158,48,0.2)",
        },
        barBorderRadius: 10,
      },
      data: [100, 100, 100, 100, 100, 100, 100, 100, 100],
      z: 0,
      zlevel: 0,
    },
    {
      // 背景分隔
      type: "pictorialBar",
      itemStyle: {
        normal: {
          color: "#0F375F",
        },
      },
      symbolRepeat: "fixed",
      symbolMargin: 3,
      symbol: "rect",
      symbolClip: true,
      symbolSize: [30, 3],
      symbolPosition: "start",
      symbolOffset: [0, -1],
      // symbolBoundingData: this.total,
      data: [100, 100, 100, 100, 100, 100, 100, 100, 100],
      width: 25,
      z: 0,
      zlevel: 1,
    },
  ],
};
4.1.2 柱状图-2

代码

const img = "/asset/get/s/data-1599036857057-CXTCW0JiG.png";

option = {
  backgroundColor: "#040c28",
  color: ["#081542"],
  tooltip: {
    trigger: "item",
  },
  grid: {
    left: "3%", //整个曲线居左的距离
    right: "4%", //整个曲线居右左的距离
    bottom: "10%", //整个曲线居下左的距离
    height: "70%", //整个曲线的高
    containLabel: true,
  },
  xAxis: [
    {
      type: "category",
      axisTick: {
        show: false,
        color: "#707070",
      },

      axisLabel: {
        textStyle: {
          fontSize: 14,
          color: "#597faa",
        },
      },
      axisLine: {
        show: false,
        lineStyle: {
          color: "#00FF00",
        },
      },
      data: ["2016.8", "2017.8", "2018.8", "2019.8", "2020.8"],
    },
  ],
  yAxis: [
    {
      type: "value",
      name: "",
      nameTextStyle: {
        fontSize: 14, //文字大小
        color: "#ebf8ac", //文字颜色
      },
      axisLine: {
        // 坐标轴轴线相关设置
        show: false,
      },
      axisTick: {
        // 坐标轴刻度
        show: false,
      },
      axisLabel: {
        show: true,
        // formatter: "{value} %", //左侧单位添加后缀
        textStyle: {
          color: "#597faa", //Y轴的数据字体颜色
        },
      },
      splitLine: {
        show: true, //网格线显示
        lineStyle: {
          type: "dashed",
          color: "rgba(255,255,255,.2)",
        },
      },
    },
  ],
  series: [
    {
      name: "",
      type: "bar",
      barWidth: "50", //柱状图宽度
      data: [12, 32, 12, 32, 32],
      barCategoryGap: "60%",
      symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
      itemStyle: {
        normal: {
          color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
            {
              offset: 0,
              color: "rgba(12, 24, 67, 0.1)",
            },
            {
              offset: 0.5,
              color: "rgba(12, 24, 67, 0.5)",
            },
            {
              offset: 1,
              color: "#051342",
            },
          ]),
        },
      },
      label: {
        normal: {
          show: true,
          position: ["50%", "0%"],
          textStyle: {
            color: "#fff",
            fontSize: 16,
            align: "center",
          },
          formatter: (val) => {
            return [val.data, "{img|}"].join("\n");
          },

          rich: {
            img: {
              backgroundColor: {
                image: img,
              },
              height: 40,
            },
          },
        },
      },
    },
  ],
};
4.1.3 柱状图-3

代码: 

 // 计划产值
 var zzx1 = [27, 38, 41, 21, 27];
 var zx = zzx1.map((item) => {
     return 100 - item;
 });
 // 实际产值
 var wgx1 = [37, 40, 63, 61, 64];
 var wg = wgx1.map((item) => {
     return 100 - item;
 });




 var barWidth = 40;
 option = {
     backgroundColor: "#010243",
     tooltip: {
         trigger: "axis",
         axisPointer: {
             // 坐标轴指示器,坐标轴触发有效
             type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
         },
         formatter: function(e) {
             // console.log(e);
             var str =
                 e[6].axisValue +
                 "<br>" +
                 "<span style='display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:" +
                 e[6].color.colorStops[0].color +
                 ";'></span>" +
                 "" +
                 e[6].seriesName +
                 " : " +
                 e[6].value +
                 "%<br>" +
                 "<span style='display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:" +
                 e[8].color.colorStops[0].color +
                 ";'></span>" +
                 "" +
                 e[8].seriesName +
                 " : " +
                 e[8].value +
                 "%";
             return str;
         },
     },
     grid: {
         left: "2%",
         right: "4%",
         bottom: "4%",
         top: "16%",
         containLabel: true,
     },
     legend: {
         data: ["计划产值", "实际产值"],

         top: 1,
         textStyle: {
             color: "#00ffff",
             fontSize: 14,
         },
         itemWidth: 12,
         itemHeight: 10,
         itemGap: 35,
         color: "#242424",
         selectedMode: false,
     },
     xAxis: {
         type: "category",
         data: [
             "A高速公路建设项目质量合格率",
             "B高速公路建设项目质量合格率",
             "C高速公路建设项目质量合格率",
             "D高速公路建设项目质量合格率",
             "E高速公路建设项目质量合格率",
         ],
         axisLine: {
             show: true,
             lineStyle: {
                 color: "#15205B",
             },
         },
         axisTick: {
             show: false,
         },
         axisLabel: {
             // interval: 0,
             // rotate: 40,
             textStyle: {
                 fontFamily: "Microsoft YaHei",
                 color: "#fff", // x轴颜色
                 fontWeight: "normal",
                 fontSize: "14",
                 lineHeight: 22,
             },
             interval: 0, //标签设置为全部显示
             margin: 15,
             lineHeight: 15,
             // fontSize: 11,
             formatter: function(params) {
                 var a = params.substring(0, params.length - 5);
                 //   console.log(params.substring(0, params.length - 3));
                 var newParamsName = a + "\n质量合格率";

                 //将最终的字符串返回
                 return newParamsName;
             },
         },
     },

     yAxis: {
         min: 0,
         max: 100,
         type: "value",

         axisLine: {
             show: true,
             lineStyle: {
                 color: "#15205B",
             },
         },
         splitLine: {
             show: false,
             lineStyle: {
                 color: "rgba(135,140,147,1)", //左侧显示线
             },
         },
         axisTick: {
             show: false,
         },
         axisLabel: {
             formatter: "{value}%",
             textStyle: {
                 color: "#c9c9c9",
                 fontSize: 14,
             },
         },
     },
     series: [
         // 计划产值中间正方形
         {
             type: "pictorialBar",
             symbol: "diamond",

             symbolSize: [barWidth, 8],
             symbolOffset: [-26, -4],
             symbolPosition: "end",
             z: 12,
             color: "#3185FF",
             data: zzx1,
         },
         // 实际产值中间正方形
         {
             type: "pictorialBar",
             symbol: "diamond",
             symbolSize: [barWidth, 8],
             symbolOffset: [26, -4],
             symbolPosition: "end",
             z: 12,
             color: "#1BCC98",
             data: wgx1,
         },
         //  计划产值底部正方形
         {
             type: "pictorialBar",
             symbol: "diamond",
             symbolSize: [barWidth, 8],
             symbolOffset: [-26, 4],
             z: 12,
             color: "#161D6E",
             data: zzx1,
         },
         // 实际产值底部正方形
         {
             name: "",
             type: "pictorialBar",
             symbol: "diamond",
             symbolSize: [barWidth, 8],
             symbolOffset: [26, 4],
             color: "#151D6E",
             z: 12,
             data: wgx1,
         },
         // 计划产值上部正方形
         {
             data: [100, 100, 100, 100, 100],
             type: "pictorialBar",

             symbol: "diamond",
             symbolSize: [barWidth, 8],
             symbolOffset: [-26, -4],
             color: "#283190",

             symbolPosition: "end",
         },
         // 实际产值上部正方形
         {
             data: [100, 100, 100, 100, 100],
             type: "pictorialBar",

             symbol: "diamond",
             symbolSize: [barWidth, 8],
             symbolOffset: [26, -4],
             color: "#283190",

             symbolPosition: "end",
         },
         // 计划产值进度柱子
         {
             name: "计划产值",
             type: "bar",
             barWidth: barWidth,
             // zlevel: 2,
             stack: "1",
             itemStyle: {
                 normal: {
                     opacity: 0.7,
                     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                             offset: 0,
                             color: "#2863D2",
                         },
                         {
                             offset: 1,
                             color: "#161D6E",
                         },
                     ]),
                     barBorderRadius: 0,
                 },
             },
             label: {
                 show: true,
                 position: ["-18", "-18"],
                 color: "#00f8ff",
                 fontSize: 12,
             },
             data: zzx1,
         },
         // 计划产值底部柱子
         {
             data: zx,
             type: "bar",

             barWidth: barWidth,
             stack: "1",

             zlevel: -1,
             itemStyle: {
                 normal: {
                     opacity: 0.7,
                     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                             offset: 0,
                             color: "#182075",
                         },
                         {
                             offset: 1,
                             color: "#182075",
                         },
                     ]),
                     barBorderRadius: 0,
                 },
             },
         },
         // 实际产值进度柱子
         {
             name: "实际产值",
             type: "bar",
             stack: "2",
             barWidth: barWidth,
             itemStyle: {
                 normal: {
                     opacity: 0.7,
                     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                             offset: 0,
                             color: "#19958B",
                         },
                         {
                             offset: 1,
                             color: "#151B6F",
                         },
                     ]),
                     barBorderRadius: 0,
                 },
             },
             label: {
                 show: true,
                 position: ["18", "-18"],
                 color: "#00f8ff",
                 fontSize: 12,
             },
             data: wgx1,
         },
         // 实际产值底部柱子
         {
             data: wg,
             type: "bar",
             barWidth: barWidth,
             stack: "2",

             zlevel: -1,
             itemStyle: {
                 normal: {
                     opacity: 0.7,
                     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                             offset: 0,
                             color: "#182075",
                         },
                         {
                             offset: 1,
                             color: "#182075",
                         },
                     ]),
                     barBorderRadius: 0,
                 },
             },
         },
     ],
 };
4.1.4 柱状图-4

代码: 

var xdata = ['苏州市', '无锡市', '南京市'];
var data = [70, 60, 80];
var maxArr = [100, 100, 100];
option = {
    backgroundColor: "rgba(5,39,58,1)", //背景色
    tooltip: {
        trigger: "axis",
        axisPointer: { // 坐标轴指示器,坐标轴触发有效
            type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
        },
        // borderRadius: 5,
        // borderColor: "#6baab2",
        // borderWidth: 1,
        formatter: function(params) { // params[0].data.nameCode
            let dot = '<span style="display:inline-block;margin-right:5px;border-radius:50%;width:10px;height:10px;background-color:#02C4DD"></span>';
            return (
              params[0].name +
              "<br>" +
              "杆塔数量 :" +
              params[0].value
            );
        }
    },
    grid: {
        left: "4%",
        right: "4%",
        bottom: "3%",
        top: "15%",
        containLabel: true
    },
    xAxis: {
        data: xdata,
        triggerEvent: true,
        axisTick: {
            show: false
        },
        axisLine: {
            show: false
        },
        axisLabel: {
            show: true,
            rotate: 0,
            interval: 0,
            textStyle: {
                padding: [14,0,0,0],
                fontSize: 14,
                color: "rgba(255,255,255,1)"
            }
        }
    },
    yAxis: {
        name: "单位:个数",
        triggerEvent: true,
        nameTextStyle: {
            color: "rgba(255,255,255,1)",
            fontSize: 16,
            padding: [0,0,10,-20]
        },
        splitLine: {
            show: true,
            lineStyle: {
                color: 'rgba(255,255,255,.1)'
            }
        },
        axisTick: {
            show: false
        },
        axisLine: {
            show: true,
             lineStyle: {
                color: 'rgba(255,255,255,.1)'
            }
        },
        axisLabel: {
            show: true,
            textStyle: {
                color: "rgb(148,159,167)",
                fontSize: 16
            }
        }
    },
    // color: ["#e54035"],
    series: [{
            name: "数量",
            barMinHeight: 10,
            type: "pictorialBar",
            barCategoryGap: "60%",
            // symbol: 'path://M0,10 L10,10 L5,0 L0,10 z',
            symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
            itemStyle: {
                normal: {
                    //barBorderRadius: 5,
                    //渐变色
                    color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                            offset: 0,
                            color: "#01EAED"
                        },
                        {
                            offset: 0.5,
                            color: "#02C4DD"
                        },
                        {
                            offset: 1,
                            color: "#029ED9"
                        }
                    ])
                }
            },
            label: {
                normal: {
                    show: true,
                    position: "top",
                    textStyle: {
                        color: "#fff",
                        fontSize:20
                    }
                }
            },
            data: data,
            z: 10
        },
        {
            name: "hill",
            type: "bar",
            barWidth: '20%',
            symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
            itemStyle: {
                normal: {
                    color: "rgba(11,47,68,.8)"
                }
            },
            data: maxArr,
            z: 9
        }
    ]
}
4.2 折线图
4.2.1 折线图-1

代码:

option = {
    backgroundColor: '#0E204A',
    tooltip: {
        trigger: 'axis',
        axisPointer: {
            lineStyle: {
                color: {
                    type: 'linear',
                    x: 0,
                    y: 0,
                    x2: 0,
                    y2: 1,
                    colorStops: [{
                        offset: 0,
                        color: 'rgba(255,255,255,0)' // 0% 处的颜色
                    }, {
                        offset: 0.5,
                        color: 'rgba(255,255,255,1)' // 100% 处的颜色
                    }, {
                        offset: 1,
                        color: 'rgba(255,255,255,0)' // 100% 处的颜色
                    }],
                    global: false // 缺省为 false
                }
            },
        },

    },
    grid: {
        top: '18%',
        left: '1%',
        right: '1%',
        bottom: '25%',
        // containLabel: true
    },
    xAxis: [{
        type: 'category',
        boundaryGap: true,
        axisLine: { //坐标轴轴线相关设置。数学上的x轴
            show: true,
            lineStyle: {
                color: 'rgba(255,255,255,0.4)'
            },
        },
        axisLabel: { //坐标轴刻度标签的相关设置
            textStyle: {
                color: '#d1e6eb',
                margin: 15,
            },
        },
        axisTick: {
            show: false,
        },
        data: ['2014', '2015', '2016', '2017', '2018', '2019'],
    }],
    yAxis: [{
        type: 'value',
        min: 0,
        // max: 140,
        splitNumber: 4,
        splitLine: {
            show: true,
            lineStyle: {
                color: 'rgba(255,255,255,0.1)'
            }
        },
        axisLine: {
            show: false,
        },
        axisLabel: {
            show: false,
            margin: 20,
            textStyle: {
                color: '#d1e6eb',

            },
        },
        axisTick: {
            show: false,
        },
    }],
    series: [{
        name: '注册总量',
        type: 'line',
        // smooth: true, //是否平滑曲线显示
        // 			symbol:'circle',  // 默认是空心圆(中间是白色的),改成实心圆
        showAllSymbol: true,
        // symbol: 'image://./static/images/guang-circle.png',
        symbolSize: 8,
        lineStyle: {
            normal: {
                color: "#53fdfe", // 线条颜色
            },
            borderColor: '#f0f'
        },
        label: {
            show: true,
            position: 'top',
            textStyle: {
                color: '#fff',
            }
        },
        itemStyle: {
            normal: {
                color: "rgba(255,255,255,1)",
            }
        },
        tooltip: {
            show: false
        },
        areaStyle: { //区域填充样式
            normal: {
                //线性渐变,前4个参数分别是x0,y0,x2,y2(范围0~1);相当于图形包围盒中的百分比。如果最后一个参数是‘true’,则该四个值是绝对像素位置。
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                        offset: 0,
                        color: 'rgba(0,150,239,0.3)'
                    },
                    {
                        offset: 1,
                        color: 'rgba(0,253,252,0)'
                    }
                ], false),
                shadowColor: 'rgba(53,142,215, 0.9)', //阴影颜色
                shadowBlur: 20 //shadowBlur设图形阴影的模糊大小。配合shadowColor,shadowOffsetX/Y, 设置图形的阴影效果。
            }
        },
        data: [150, 200, 259, 360, 378, 450, 450]
    }]
};
4.2.2 折线图-2

代码:

option = {
    backgroundColor: '#080b30',
    title: {
        text: '多线图',
        textStyle: {
            align: 'center',
            color: '#fff',
            fontSize: 20,
        },
        top: '5%',
        left: 'center',
    },
    tooltip: {
        trigger: 'axis',
        axisPointer: {
            lineStyle: {
                color: {
                    type: 'linear',
                    x: 0,
                    y: 0,
                    x2: 0,
                    y2: 1,
                    colorStops: [{
                        offset: 0,
                        color: 'rgba(0, 255, 233,0)'
                    }, {
                        offset: 0.5,
                        color: 'rgba(255, 255, 255,1)',
                    }, {
                        offset: 1,
                        color: 'rgba(0, 255, 233,0)'
                    }],
                    global: false
                }
            },
        },
    },
    grid: {
        top: '15%',
        left: '5%',
        right: '5%',
        bottom: '15%',
        // containLabel: true
    },
    xAxis: [{
        type: 'category',
        axisLine: {
            show: true
        },
        splitArea: {
            // show: true,
            color: '#f00',
            lineStyle: {
                color: '#f00'
            },
        },
        axisLabel: {
            color: '#fff'
        },
        splitLine: {
            show: false
        },
        boundaryGap: false,
        data: ['A', 'B', 'C', 'D', 'E', 'F'],

    }],

    yAxis: [{
        type: 'value',
        min: 0,
        // max: 140,
        splitNumber: 4,
        splitLine: {
            show: true,
            lineStyle: {
                color: 'rgba(255,255,255,0.1)'
            }
        },
        axisLine: {
            show: false,
        },
        axisLabel: {
            show: false,
            margin: 20,
            textStyle: {
                color: '#d1e6eb',

            },
        },
        axisTick: {
            show: false,
        },
    }],
    series: [{
            name: '注册总量',
            type: 'line',
            smooth: true, //是否平滑
            showAllSymbol: true,
            // symbol: 'image://./static/images/guang-circle.png',
            symbol: 'circle',
            symbolSize: 15,
            lineStyle: {
                normal: {
                    color: "#00b3f4",
                    shadowColor: 'rgba(0, 0, 0, .3)',
                    shadowBlur: 0,
                    shadowOffsetY: 5,
                    shadowOffsetX: 5,
                },
            },
            label: {
                show: true,
                position: 'top',
                textStyle: {
                    color: '#00b3f4',
                }
            },
            itemStyle: {
                color: "#00b3f4",
                borderColor: "#fff",
                borderWidth: 3,
                shadowColor: 'rgba(0, 0, 0, .3)',
                shadowBlur: 0,
                shadowOffsetY: 2,
                shadowOffsetX: 2,
            },
            tooltip: {
                show: false
            },
            areaStyle: {
                normal: {
                    color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                            offset: 0,
                            color: 'rgba(0,179,244,0.3)'
                        },
                        {
                            offset: 1,
                            color: 'rgba(0,179,244,0)'
                        }
                    ], false),
                    shadowColor: 'rgba(0,179,244, 0.9)',
                    shadowBlur: 20
                }
            },
            data: [502.84, 205.97, 332.79, 281.55, 398.35, 214.02, ]
        },
        {
            name: '注册总量',
            type: 'line',
            smooth: true, //是否平滑
            showAllSymbol: true,
            // symbol: 'image://./static/images/guang-circle.png',
            symbol: 'circle',
            symbolSize: 15,
            lineStyle: {
                normal: {
                    color: "#00ca95",
                    shadowColor: 'rgba(0, 0, 0, .3)',
                    shadowBlur: 0,
                    shadowOffsetY: 5,
                    shadowOffsetX: 5,
                },
            },
            label: {
                show: true,
                position: 'top',
                textStyle: {
                    color: '#00ca95',
                }
            },

            itemStyle: {
                color: "#00ca95",
                borderColor: "#fff",
                borderWidth: 3,
                shadowColor: 'rgba(0, 0, 0, .3)',
                shadowBlur: 0,
                shadowOffsetY: 2,
                shadowOffsetX: 2,
            },
            tooltip: {
                show: false
            },
            areaStyle: {
                normal: {
                    color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                            offset: 0,
                            color: 'rgba(0,202,149,0.3)'
                        },
                        {
                            offset: 1,
                            color: 'rgba(0,202,149,0)'
                        }
                    ], false),
                    shadowColor: 'rgba(0,202,149, 0.9)',
                    shadowBlur: 20
                }
            },
            data: [281.55, 398.35, 214.02, 179.55, 289.57, 356.14, ],
        },
    ]
};
4.2.3 折线图-3

代码:

option = {
    backgroundColor: "#05224d",
    tooltip: {},
    grid: {
        top: '8%',
        left: '1%',
        right: '1%',
        bottom: '8%',
        containLabel: true,
    },
    legend: {
        itemGap: 50,
        data: ['注册总量' ,'最新注册量'],
        textStyle: {
            color: '#f9f9f9',
            borderColor: '#fff'
        },
    },
    xAxis: [{
        type: 'category',
        boundaryGap: true,
        axisLine: { //坐标轴轴线相关设置。数学上的x轴
            show: true,
            lineStyle: {
                color: '#f9f9f9'
            },
        },
        axisLabel: { //坐标轴刻度标签的相关设置
            textStyle: {
                color: '#d1e6eb',
                margin: 15,
            },
        },
        axisTick: {
            show: false,
        },
        data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', ],
    }],
    yAxis: [{
        type: 'value',
        min: 0,
        // max: 140,
        splitNumber: 7,
        splitLine: {
            show: true,
            lineStyle: {
                color: '#0a3256'
            }
        },
        axisLine: {
            show: false,
        },
        axisLabel: {
            margin: 20,
            textStyle: {
                color: '#d1e6eb',

            },
        },
        axisTick: {
            show: false,
        },
    }],
    series: [{
        name: '注册总量',
        type: 'line',
        // smooth: true, //是否平滑曲线显示
        // 			symbol:'circle',  // 默认是空心圆(中间是白色的),改成实心圆
        showAllSymbol: true,
        symbol: 'emptyCircle',
        symbolSize: 6,
        lineStyle: {
            normal: {
                color: "#28ffb3", // 线条颜色
            },
            borderColor: '#f0f'
        },
        label: {
            show: true,
            position: 'top',
            textStyle: {
                color: '#fff',
            }
        },
        itemStyle: {
            normal: {
                color: "#28ffb3",

            }
        },
        tooltip: {
            show: false
        },
        areaStyle: { //区域填充样式
            normal: {
                //线性渐变,前4个参数分别是x0,y0,x2,y2(范围0~1);相当于图形包围盒中的百分比。如果最后一个参数是‘true’,则该四个值是绝对像素位置。
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                        offset: 0,
                        color: 'rgba(0,154,120,1)'
                    },
                    {
                        offset: 1,
                        color: 'rgba(0,0,0, 0)'
                    }
                ], false),
                shadowColor: 'rgba(53,142,215, 0.9)', //阴影颜色
                shadowBlur: 20 //shadowBlur设图形阴影的模糊大小。配合shadowColor,shadowOffsetX/Y, 设置图形的阴影效果。
            }
        },
        data: [393, 438, 485, 631, 689, 824, 987]
    }, {
        name: '最新注册量',
        type: 'bar',
        barWidth: 20,
        tooltip: {
            show: false
        },
         label: {
            show: true,
            position: 'top',
            textStyle: {
                color: '#fff',
            }
        },
        itemStyle: {
            normal: {
                // barBorderRadius: 5,
                // color: new echarts.graphic.LinearGradient(
                //     0, 0, 0, 1,
                //     [{
                //             offset: 0,
                //             color: '#14c8d4'
                //         },
                //         {
                //             offset: 1,
                //             color: '#43eec6'
                //         }
                //     ]
                // )
                color: function(params) {
                    var colorList = ['#0ec1ff', '#10cdff', '#12daff', '#15ebff', '#17f8ff', '#1cfffb', '#1dfff1'];
                    return colorList[params.dataIndex];
                }
            }
        },
        data: [200, 382, 102, 267, 186, 315, 316]
    }]
};
4.3 饼图
4.3.1 饼图-1

代码:

var img =
  "";

var trafficWay = [
  {
    name: "火车",
    value: 20,
  },
  {
    name: "飞机",
    value: 10,
  },
  {
    name: "客车",
    value: 30,
  },
  {
    name: "轮渡",
    value: 40,
  },
];

var data = [];
var color = [
  "#00ffff",
  "#00cfff",
  "#006ced",
  "#ffe000",
  "#ffa800",
  "#ff5b00",
  "#ff3000",
];
for (var i = 0; i < trafficWay.length; i++) {
  data.push(
    {
      value: trafficWay[i].value,
      name: trafficWay[i].name,
      itemStyle: {
        normal: {
          borderWidth: 5,
          shadowBlur: 20,
          borderColor: color[i],
          shadowColor: color[i],
        },
      },
    },
    {
      value: 2,
      name: "",
      itemStyle: {
        normal: {
          label: {
            show: false,
          },
          labelLine: {
            show: false,
          },
          color: "rgba(0, 0, 0, 0)",
          borderColor: "rgba(0, 0, 0, 0)",
          borderWidth: 0,
        },
      },
    }
  );
}
var seriesOption = [
  {
    name: "",
    type: "pie",
    clockWise: false,
    radius: [105, 109],
    hoverAnimation: false,
    itemStyle: {
      normal: {
        label: {
          show: true,
          position: "outside",
          color: "#ddd",
          formatter: function (params) {
            var percent = 0;
            var total = 0;
            for (var i = 0; i < trafficWay.length; i++) {
              total += trafficWay[i].value;
            }
            percent = ((params.value / total) * 100).toFixed(0);
            if (params.name !== "") {
              return (
                "交通方式:" +
                params.name +
                "\n" +
                "\n" +
                "占百分比:" +
                percent +
                "%"
              );
            } else {
              return "";
            }
          },
        },
        labelLine: {
          length: 30,
          length2: 100,
          show: true,
          color: "#00ffff",
        },
      },
    },
    data: data,
  },
];
option = {
  backgroundColor: "#0A2E5D",
  color: color,
  title: {
    text: "交通方式",
    top: "48%",
    textAlign: "center",
    left: "49%",
    textStyle: {
      color: "#fff",
      fontSize: 22,
      fontWeight: "400",
    },
  },
  graphic: {
    elements: [
      {
        type: "image",
        z: 3,
        style: {
          image: img,
          width: 178,
          height: 178,
        },
        left: "center",
        top: "center",
        position: [100, 100],
      },
    ],
  },
  tooltip: {
    show: false,
  },
  legend: {
    icon: "circle",
    orient: "horizontal",
    // x: 'left',
    data: ["火车", "飞机", "客车", "轮渡"],
    right: 340,
    bottom: 150,
    align: "right",
    textStyle: {
      color: "#fff",
    },
    itemGap: 20,
  },
  toolbox: {
    show: false,
  },
  series: seriesOption,
};
4.3.2 饼图-2

 

代码:

let angle = 0;//角度,用来做简单的动画效果的
let value = 55.33;
option = {
backgroundColor:"#061740",
title: {
        text: '{a|'+ value +'}{c|%}',
        x: 'center',
        y: 'center',
        textStyle: {
            rich:{
                a: {
                    fontSize: 48,
                    color: '#29EEF3'
                },
                
                c: {
                    fontSize: 20,
                    color: '#ffffff',
                    // padding: [5,0]
                }
            }
        }
    },
    legend: {
        type: "plain",
        orient: "vertical",
        right: 0,
        top: "10%",
        align: "auto",
        data: [{
            name: '涨价后没吃过',
            icon: "circle"
        }, {
            name: '天天吃',
            icon: "circle"
        }, {
            name: '三五天吃一次',
            icon: "circle"
        }, {
            name: '半个月吃一次',
            icon: "circle"
        }],
        textStyle: {
            color: "white",
            fontSize: 16,
            padding: [10, 1, 10, 0]
        },
        selectedMode:false
    },
    series: [ {
            name: "ring5",
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                return {
                    type: 'arc',
                    shape: {
                        cx: api.getWidth() / 2,
                        cy: api.getHeight() / 2,
                        r: Math.min(api.getWidth(), api.getHeight()) / 2 * 0.6,
                        startAngle: (0+angle) * Math.PI / 180,
                        endAngle: (90+angle) * Math.PI / 180
                    },
                    style: {
                        stroke: "#0CD3DB",
                        fill: "transparent",
                        lineWidth: 1.5
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: "ring5",
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                return {
                    type: 'arc',
                    shape: {
                        cx: api.getWidth() / 2,
                        cy: api.getHeight() / 2,
                        r: Math.min(api.getWidth(), api.getHeight()) / 2 * 0.6,
                        startAngle: (180+angle) * Math.PI / 180,
                        endAngle: (270+angle) * Math.PI / 180
                    },
                    style: {
                        stroke: "#0CD3DB",
                        fill: "transparent",
                        lineWidth: 1.5
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: "ring5",
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                return {
                    type: 'arc',
                    shape: {
                        cx: api.getWidth() / 2,
                        cy: api.getHeight() / 2,
                        r: Math.min(api.getWidth(), api.getHeight()) / 2 * 0.65,
                        startAngle: (270+-angle) * Math.PI / 180,
                        endAngle: (40+-angle) * Math.PI / 180
                    },
                    style: {
                        stroke: "#0CD3DB",
                        fill: "transparent",
                        lineWidth: 1.5
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: "ring5",
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                return {
                    type: 'arc',
                    shape: {
                        cx: api.getWidth() / 2,
                        cy: api.getHeight() / 2,
                        r: Math.min(api.getWidth(), api.getHeight()) / 2 * 0.65,
                        startAngle: (90+-angle) * Math.PI / 180,
                        endAngle: (220+-angle) * Math.PI / 180
                    },
                    style: {
                        stroke: "#0CD3DB",
                        fill: "transparent",
                        lineWidth: 1.5
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: "ring5",
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                let x0 = api.getWidth() / 2;
                let y0 = api.getHeight() / 2;
                let r = Math.min(api.getWidth(), api.getHeight()) / 2 * 0.65;
                let point = getCirlPoint(x0, y0, r, (90+-angle))
                return {
                    type: 'circle',
                    shape: {
                        cx: point.x,
                        cy: point.y,
                        r: 4
                    },
                    style: {
                        stroke: "#0CD3DB",//粉
                        fill: "#0CD3DB"
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: "ring5",  //绿点
            type: 'custom',
            coordinateSystem: "none",
            renderItem: function(params, api) {
                let x0 = api.getWidth() / 2;
                let y0 = api.getHeight() / 2;
                let r = Math.min(api.getWidth(), api.getHeight()) / 2 * 0.65;
                let point = getCirlPoint(x0, y0, r, (270+-angle))
                return {
                    type: 'circle',
                    shape: {
                        cx: point.x,
                        cy: point.y,
                        r: 4
                    },
                    style: {
                        stroke: "#0CD3DB",      //绿
                        fill: "#0CD3DB"
                    },
                    silent: true
                };
            },
            data: [0]
        }, {
            name: '吃猪肉频率',
            type: 'pie',
            radius: ['58%', '45%'],
            silent: true,
            clockwise: true,
            startAngle: 90,
            z: 0,
            zlevel: 0,
            label: {
                normal: {
                    position: "center",

                }
            },
            data: [{
                    value: value,
                    name: "",
                    itemStyle: {
                        normal: {
                            color: { // 完成的圆环的颜色
                                colorStops: [{
                                    offset: 0,
                                    color: '#4FADFD' // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: '#28E8FA' // 100% 处的颜色
                                }]
                            },
                        }
                    }
                },
                {
                    value: 100-value,
                    name: "",
                    label: {
                        normal: {
                            show: false
                        }
                    },
                    itemStyle: {
                        normal: {
                            color: "#173164"
                        }
                    }
                }
            ]
        },
        
        {
            name: "",
            type: "gauge",
            radius: "58%",
            center: ['50%', '50%'],
            startAngle: 0,
            endAngle: 359.9,
            splitNumber: 8,
            hoverAnimation: true,
            axisTick: {
                show: false
            },
            splitLine: {
                length: 60,
                lineStyle: {
                    width: 5,
                    color: "#061740"
                }
            },
            axisLabel: {
                show: false
            },
            pointer: {
                show: false
            },
            axisLine: {
                lineStyle: {
                    opacity: 0
                }
            },
            detail: {
                show: false
            },
            data: [{
                value: 0,
                name: ""
            }]
        },
        
    ]
};

//获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度)
function getCirlPoint(x0, y0, r, angle) {
    let x1 = x0 + r * Math.cos(angle * Math.PI / 180)
    let y1 = y0 + r * Math.sin(angle * Math.PI / 180)
    return {
        x: x1,
        y: y1
    }
}

function draw(){
    angle = angle+3
    myChart.setOption(option, true)
   //window.requestAnimationFrame(draw);
}

setInterval(function() {
    //用setInterval做动画感觉有问题
    draw()
}, 100);

 

4.3.3 饼图-3
  • 27
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
ECharts 是一款基于 JavaScript 的开源可视化图表库,支持多种类型的图表,如折线图、柱状图、饼图等。下面简单介绍一下使用 ECharts 实现可视化图表的步骤: 1. 引入 ECharts 库 在 HTML 文件中引入 ECharts 库,可以从官网下载或使用 CDN 引入。例如: ```html <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> ``` 2. 准备数据 准备需要展示的数据,可以是数组、对象等形式。例如: ```javascript const data = [ { name: '北京', value: 100 }, { name: '上海', value: 200 }, { name: '广州', value: 150 }, { name: '深圳', value: 180 } ]; ``` 3. 创建容器 在 HTML 文件中创建一个容器,用于展示图表。例如: ```html <div id="chart" style="width: 600px; height:400px"></div> ``` 4. 初始化图表JavaScript 文件中获取容器对象,并使用 ECharts 的 `init` 方法初始化图表。例如: ```javascript const chart = echarts.init(document.getElementById('chart')); ``` 5. 配置图表 使用 ECharts 的配置项配置图表,如设置图表类型、数据、颜色、样式等。例如: ```javascript const option = { title: { text: '城市销售情况' }, tooltip: {}, xAxis: { data: data.map(item => item.name) }, yAxis: {}, series: [{ name: '销量', type: 'bar', data: data.map(item => item.value), itemStyle: { color: '#3398DB' } }] }; ``` 6. 渲染图表 使用 ECharts 的 `setOption` 方法渲染图表。例如: ```javascript chart.setOption(option); ``` 完整的代码如下: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ECharts Demo</title> <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> </head> <body> <div id="chart" style="width: 600px; height:400px"></div> <script> const data = [ { name: '北京', value: 100 }, { name: '上海', value: 200 }, { name: '广州', value: 150 }, { name: '深圳', value: 180 } ]; const chart = echarts.init(document.getElementById('chart')); const option = { title: { text: '城市销售情况' }, tooltip: {}, xAxis: { data: data.map(item => item.name) }, yAxis: {}, series: [{ name: '销量', type: 'bar', data: data.map(item => item.value), itemStyle: { color: '#3398DB' } }] }; chart.setOption(option); </script> </body> </html> ``` 这是一个简单的柱状图示例,实际上 ECharts 还支持更多类型的图表和更多的配置项。需要根据实际需求进行调整。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进阶的疯狗der

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值