Echarts数据可视化

Posted 苦海123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Echarts数据可视化相关的知识,希望对你有一定的参考价值。

数据可视化概念:

把数据以图表的方式体现,更加直观可见,如下文字和图表对比:

数据可视化实现的方式:

报表类:Excel 、水晶报表等,面向非技术人员,点击图标即可生成图表,非常不灵活。

商业智能BI:Microsoft BI 、Power-BI等,也可以展示图表信息,并且可以自己做出决策,

编码类:Echarts.js、D3.js、Chart.js等,灵活性高,可视化度高,需要有编码经验的工程师才能开发。

echarts简介:

ECharts是一款基于javascript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。ECharts最初由百度团队开源,兼容性极好,支持pc和移动等多端,开源免费,社区活跃,并于2018年初捐赠给Apache基金会,成为ASF孵化级项目;JavaScript数据可视化库有很多种,常用的如:D3.js、Recharts、Chart.js等,ECharts 其官网:https://echarts.apache.org/zh/index.html

多种数据格式支持:

key-value、二维表、typedarray格式

流数据的支持:支持加载多少数据,渲染多少数据。

增量渲染技术:变化的渲染数据,可以提高性能。

Echarts基本使用:

1.引入echarts.js文件:框架开发中支持模块化导入

2.准备一个呈现图表的容器(div):给上尺寸

3.初始化echarts实例对象:

4.准备配置项:

5.将配置项设置给echarts实例对象

原生js中使用:

<body>
  <!-- 1.引入echarts.js文件:,如果是在vue等框架的支持下,可以使用模块化引入 -->
  <script src="https://cdn.jsdelivr.net/npm/echarts@5.4.0/dist/echarts.min.js"></script>
  <!-- 2.准备一个呈现图表的容器(div): -->
  <div style="width: 600px;height:500px"></div>
  <script>
    // 3.初始化一个echarts实例对象:init方法中将容器传入:init第二个参数表示主题light/dark,默认light
    // 除了给init方法传入第二个参数修改主题外,还支持自定义主题,自定义主题修改方式:进入网址对自己的主题编辑后进行下载js代码:https://echarts.apache.org/zh/theme-builder.html,之后引入js代码,并将init第二个参数名称改为自己主题命名的自定义主题名称。
    const myChart = echarts.init(document.querySelector('div'),'dark')
    // 4.准备配置项:
    const options = 
      // 全局配置调色
      color: ['pink', 'blue'],
      xAxis: 
        type: 'category',
        data: ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
      ,
      yAxis: 
        type: 'value'
      ,
      series: [
        
          name: '服装销量',
          type: 'bar',
          data: [5, 7, 8, 20, 2, 7, 8, 15, 5, 12, 15, 18, 12],
          // 局部配置调色  
          color: ['skyblue','#888999']
        ,
        
          name: '服装销量',
          type: 'line',
          data: [5, 7, 8, 20, 2, 7, 8, 15, 5, 12, 15, 18, 12]
        
      ]
    
    // 5.将配置项设置给echarts实例对象
    myChart.setOption(options)
  </script>
</body>

vue中使用:

<template>
  <!-- 主要盒子 -->
  <div style="width: 100%;height:100%">
    <!-- 2.准备一个呈现图表的容器(div) -->
    <div ref="alarm" style="width: 600px;height:500px"></div>
  </div>
</template>
<script>
// 1.导入echarts库,首先npm install echarts 下载库
import * as echarts from 'echarts'
export default 
  mounted () 
    // *2组件挂载后再调用方法,否则无法生成图表
    this.barEchartsHandle()
  ,
  methods: 
    // *1创建一个方法用来生成图表
    barEchartsHandle () 
      // 3.初始化一个echarts实例对象:init方法中将容器传入:
      const myChart = echarts.init(this.$refs.alarm)
      // 4.准备配置项:
      const options = 
        xAxis: 
          type: 'category',
          data: ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
        ,
        yAxis: 
          type: 'value'
        ,
        series: [
          
            name: '服装销量',
            type: 'bar',
            data: [5, 7, 8, 20, 2, 7, 8, 15, 5, 12, 15, 18, 12]
          ,
          
            name: '服装销量',
            type: 'line',
            data: [5, 7, 8, 20, 2, 7, 8, 15, 5, 12, 15, 18, 12]
          
        ]
      
      // 5.将配置项设置给echarts实例对象
      myChart.setOption(options)
    
  

</script>
 <style lang="less" scoped></style>

效果图:

echarts中配置项options

echarts中配置项options配置非常多,下面简单介绍常用配置项:

通用配置:这些通用配置会在下面Echarts中常用7大类图表中体现出,稍微注意就可以。

标题title(标题样式textStyle、标题宽度borderWidth、标题颜色borderColor、标题圆角borderRadius)

提示框tooltip,鼠标滑过会出现提示框,触发类型trigger(item/axis)、触发时机triggerOn(mousemove/click)、格式化formatter(可以接收字符串、模板字符串、有返回值的回调函数,模板变量时有特殊含义变量:系列名a、数据名b、数据值c、d、e、),属性较多,粘上官方文档:https://echarts.apache.org/zh/option.html#%2Fsearch%2Fformatter

工具按钮toolbox提供导出图片、重置试图、动态类型切换、数据区域缩放、数据试图五个工具

图例legend

样式:可以给某个item设置不同的样式,可分为:直接样式(itemStyle/textStyle/lineStyle/areaStyle/label)和高亮样式(在emphasis中包裹itemStyle/textStyle/lineStyle/areaStyle/label)

**重新熏染图表:**根据浏览器大小重新渲染图表大小,init的实例下有方法:resize()

加载动画:init的实例下有方法:showLoading()/hideLoading()

**私有配置:**不同的类型表有自己私有的配置属性,下面会有案例说明。

增量动画:如果要改变图表中的某些数据,还想要动画的方式体现,此时可以直接创建一个新的数据options配置对象,之后设置给原来的实例(setOption()),这里不会完全覆盖,它只会将不同的数据进行整合

Echarts中常用7大类图表:

1.柱状图:

// 配置项介绍:
    const options = 
      // 1.title:配置图表标题:
      title: 
        // text:标题文本
        text: '服装每月销售量',
        // link:配置标题超链接跳转
        link: 'http:www.baidu.com',
        // textStyle:配置标题样式:
        textStyle: 
          // color:配置标题颜色,还有部分常用属性:
          color: 'skyBlue'
        ,
        // 标题边框宽度
        borderWidth: 2,
        // 标题边框颜色
        borderColor: 'yellow',
        // 标题边框圆角
        borderRadius: 5,
        // 标题距离左边距离,标题位置有4个属性,分别:left、top、bottom、right
        left: 30,
        // 标题距离顶部边距离
        top: 10
      ,
      // 3.tooltip提示框
      tooltip: 
        // trigger触发类型:axis表示鼠标移动到轴就可以触发提示框,item表示鼠标移动到柱子上才会显示提示框
        // trigger: 'item',//主要在散点图,饼图等无类目轴的图表中使用
        trigger: 'axis',
        // triggerOn触发时机,默认mousemove表示鼠标滑过触发提示框显示,click表示点击时触发提示框显示
        triggerOn: 'mousemove',
        // formatter自定义提示框内容:直接写字符串会直接输出字符串,当为模板字符串时,会自动展示模板变量数据,多个series项时只显示第一个的数据,除非隐藏掉其他的后才会显示非第一个,模板变量规定规则:https://echarts.apache.org/zh/option.html#%2Fsearch%2Fformatter
        // formatter: `b的销量为:c`
        // formatter后面接函数时,函数参数为一个数组,每个数组元素表示一个item项,第一个元素表示鼠标经过的元素本身(当然数组中只有一个元素)
        formatter: (e) => 
          // console.log(e)
          return `<div style='background:skyblue;color:#fff;'>$e[0].name的销量为:$e[0].data</div>`
        
      ,
      // 4.toolbox工具框
      toolbox: 
        // feature需要开启的工具功能有:
        feature: 
          // 导出图片
          saveAsImage: ,
          // 数据视图
          dataView: ,
          // 重置
          restore: ,
          // 区域缩放
          dataZoom: 
            yAxisIndex: 'none'
          ,
          // magicType启用的动态类型,包括'line'(切换为折线图), 'bar'(切换为柱状图), 'stack'(切换为堆叠模式,series有多个对象配置时生效)
          magicType:  type: ['line', 'bar','stack'] ,
        
      ,
      // 3.xAxis:直角坐标系中X轴
      xAxis: 
        // type:轴类型:类目category、数值value;类目轴需要配置data轴数据,而value类型数据时series中data数据
        type: 'category',
        data: ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
      ,
      //4. yAxis:直角坐标系中y轴
      yAxis: 
        type: 'value'
      ,
      // 5.legend控制系列中某个对象显示或隐藏
      legend: 
        // data中的数组元素和series中对象的name保持一直
        data: ['服装销量','餐饮销量']
      ,
      // 6.series:系列列表,里面每个对象将生成一种类型的图表,每种图表类型可根据实际情况选择不同的类型,但是要合理,如在直角坐标系中显示饼图就不太合理了
      series: [
        
          // name:图表名称
          name: '服装销量',
          // type:图表类型名称,柱状图bar、折线图line、饼图pie
          type: 'bar',
          // 值数据:
          data: [5, 7, 8, 20, 2, 7, 8, 15, 5, 12, 15, 18, 12],
          // markPoint:配置标记点
          markPoint: 
            // data需要标记的元素
            data: [
              
                // type:标记元素的类型
                type: 'max',
                // name:标记元素的名称
                name: '最大值'
              ,
              
                type: 'min',
                name: '最小值'
              
            ]
          ,
          // markLine配置标记线
          markLine: 
            data: [
              
                type: 'average',
                name: '平均值'
              
            ]
          ,
          // label:配置显示详细数据
          label: 
            show: true,
            // rotate数值旋转显示
            rotate: 60,
            // position:配置数值位置,默认inside内部
            position: 'top'
          ,
          // barWidth配置柱状图宽度
          barWidth: '20%'
        ,
        
          name: '餐饮销量',
          type: 'line',
          data: [15, 17, 18, 30, 12, 17, 18, 25, 15, 22, 15, 28, 22],
          markPoint: 
            data: [
              
                type: 'max',
                name: '最大值'
              ,
              
                type: 'min',
                name: '最小值'
              
            ]
          ,
          markLine: 
            data: [
              
                type: 'average',
                name: '平均值'
              
            ]
          ,
          label: 
            show: true,
            rotate: 0,
            position: 'top'
          
        
      ]
    

2.折线图:

// 配置项介绍:
    const options = 
      // 1.title:配置图表标题:
      title: 
        // text:标题文本
        text: '服装每月销售量',
        // link:配置标题超链接跳转
        link: 'http:www.baidu.com',
        // textStyle:配置标题样式:
        textStyle: 
          // color:配置标题颜色,还有部分常用属性:
          color: 'skyBlue'
        ,
        // 标题边框宽度
        borderWidth: 2,
        // 标题边框颜色
        borderColor: 'yellow',
        // 标题边框圆角
        borderRadius: 5,
        // 标题距离左边距离,标题位置有4个属性,分别:left、top、bottom、right
        left: 30,
        // 标题距离顶部边距离
        top: 10
      ,
      // 3.tooltip提示框
      tooltip: 
        // trigger触发类型:axis表示鼠标移动到轴就可以触发提示框,item表示鼠标移动到柱子上才会显示提示框
        // trigger: 'item',//主要在散点图,饼图等无类目轴的图表中使用
        trigger: 'axis',
        // triggerOn触发时机,默认mousemove表示鼠标滑过触发提示框显示,click表示点击时触发提示框显示
        triggerOn: 'mousemove',
        // formatter自定义提示框内容:直接写字符串会直接输出字符串,当为模板字符串时,会自动展示模板变量数据,多个series项时只显示第一个的数据,除非隐藏掉其他的后才会显示非第一个,模板变量规定规则:https://echarts.apache.org/zh/option.html#%2Fsearch%2Fformatter
        // formatter: `b的销量为:c`
        // formatter后面接函数时,函数参数为一个数组,每个数组元素表示一个item项,第一个元素表示鼠标经过的元素本身(当然数组中只有一个元素)
        formatter: (e) => 
          // console.log(e)
          return `<div style='background:skyblue;color:#fff;'>$e[0].name的销量为:$e[0].data</div>`
        
      ,
      // 4.toolbox工具框
      toolbox: 
        // feature需要开启的工具功能有:
        feature: 
          // 导出图片
          saveAsImage: ,
          // 数据视图
          dataView: ,
          // 重置
          restore: ,
          // 区域缩放
          dataZoom: 
            yAxisIndex: 'none'
          ,
          // magicType启用的动态类型,包括'line'(切换为折线图), 'bar'(切换为柱状图), 'stack'(切换为堆叠模式,series有多个对象配置时生效)
          magicType:  type: ['line', 'bar','stack'] ,
        
      ,
      // 3.xAxis:直角坐标系中X轴
      xAxis: 
        // type:轴类型:类目category、数值value;类目轴需要配置data轴数据,而value类型数据时series中data数据
        type: 'category',
        data: ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月'],
        // 设置第一个点是否在y轴上,默认第一个点和y轴之间有距离
        boundaryGap: false
      ,
      //4. yAxis:直角坐标系中y轴
      yAxis: 
        type: 'value',
        // 配置数值轴坐标值是否不从0开始计算
        scale: true
      ,
      // 6.series:系列列表,里面每个对象将生成一种类型的图表 
      series: [
        
          // name:图表名称
          name: '服装销量',
          // type:图表类型名称,柱状图bar、折线图line、饼图pie
          type: 'line',
          // 值数据:
          data: [5, 6, 6, 5, 5, 6, 5, 5, 6, 5, 6, 5, 5],
          // markPoint:配置标记点
          markPoint: 
            // data需要标记的元素
            data: [
              
                // type:标记元素的类型
                type: 'max',
                // name:标记元素的名称
                name: '最大值'
              ,
              
                type: 'min',
                name: '最小值'
              
            ]
          ,
          // markLine配置标记线
          markLine: 
            data: [