Apache EChart前端图表

目录

[一、了解Apache EChart](#一、了解Apache EChart)

[1.1 什么是Apache Echart](#1.1 什么是Apache Echart)

[1.2 为什么要使用图表](#1.2 为什么要使用图表)

[1.3 常见的图表以及特点](#1.3 常见的图表以及特点)

[二、Apache EChart的基本使用](#二、Apache EChart的基本使用)

[2.1 下载echarts.js](#2.1 下载echarts.js)

[2.2 echart基本使用案例](#2.2 echart基本使用案例)

三、多类型图表的使用

[3.1 柱状图(type:'bar')](#3.1 柱状图(type:'bar'))

--基本柱状图

--多系列柱状图

--堆叠柱状图

--动态排序柱状图

[3.2 折线图(type:'line')](#3.2 折线图(type:'line'))

--基本折线图

--多系列折线图

--堆叠折线图

--平滑曲线图

--阶梯折线图

[3.3 饼图(type:'pie')](#3.3 饼图(type:'pie'))

--基本饼图

--圆环图

--玫瑰图

[3.4 散点图(type:'scatter')](#3.4 散点图(type:'scatter'))

--基本散点图


一、了解Apache EChart

1.1 什么是Apache Echart

1.2 为什么要使用图表

  1. 可视化效果:图表将数据转换为图形,使复杂的数据变得直观易懂。
  2. 提高用户体验:图表简化了数据解读过程,提升了用户对信息的理解速度。
  3. 简化数据解读:通过图形化展示,用户可以快速识别数据的关键趋势和模式。
  4. 促进沟通:图表有助于在团队成员间进行更有效的沟通,易于分享和理解数据。

1.3 常见的图表以及特点

柱状图:

特点:

  • 柱状图使用垂直或水平的矩形条(柱子)来表示不同类别之间的数值比较。
  • 每个柱子的高度或长度代表其对应的数值大小。
  • 柱状图清晰地展示了不同分类之间的差异,使得数据对比更加直观。

折线图:

特点:

  • 折线图使用一系列数据点连接成线段,用于显示数据随时间变化的趋势。
  • 它能够有效地展示数据的趋势和模式,特别是在一段时间内的变化趋势。
  • 折线图中的每个点代表一个数据值,线段则表示这些数据值之间的连续性。

饼图:

特点:

  • 饼图通过将圆形分割成不同的扇形区域来表示各个部分占总体的比例。
  • 每个扇形的面积与它所代表的部分在总和中的比例相对应。
  • 饼图适合于展示各个组成部分在整体中的占比情况。

散点图:

特点:

  • 散点图使用二维坐标系中的点来表示数据集中的每一对数值。
  • 点的位置反映了两个变量之间的关系,通常用于探索变量之间的相关性。
  • 如果数据点聚集在一起,则表明变量之间可能存在某种关系;如果数据点分布广泛,则表明变量之间没有明显的关系。

二、Apache EChart的基本使用

2.1 下载echarts.js

通过官网进行下载或者npm下载

bash 复制代码
npm install echarts

2.2 echart基本使用案例

html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      title: {
        text: 'ECharts 入门示例'
      },
      tooltip: {},
      xAxis: {
        data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']
      },
      yAxis: {},
      series: [
        {
          name: '销量',
          type: 'bar',
          data: [5, 20, 36, 10, 10, 20]
        }
      ]
    });
  }
}
</script>

效果展示:

基本参数选项的解释

title

  • text: 设置图表标题的文字。在这里,标题为"ECharts 入门示例"。

tooltip

  • 空对象 {} 表示采用默认的提示框样式和行为。如果需要自定义提示框的内容、样式等,可以通过向 tooltip 对象中添加属性来实现。

xAxis

  • data: 设置 X 轴的数据,即条形图的分类标签。在这里,数据为 ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']

  • 默认情况下,ECharts 会自动创建一个类目轴(category axis)用于显示这些分类。

yAxis

  • 空对象 {} 表示采用默认的 Y 轴设置。如果需要自定义 Y 轴的刻度范围、标签等,可以通过向 yAxis 对象中添加属性来实现。

series

  • series 是一个数组,其中的每个对象代表一个数据系列。

  • name: 数据系列的名称,在图例中显示。在这里,系列名称为"销量"。

  • type: 图表类型。在这里,类型为 bar,表示条形图。

  • data: 数据系列的数据值。在这里,数据为 [5, 20, 36, 10, 10, 20],对应 X 轴上的六个分类。


三、多类型图表的使用

3.1 柱状图(type:'bar')

--基本柱状图
html 复制代码
<!-- 基本柱状图 -->
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      title: {
        text: '基本柱状图'
      },
      xAxis: {
        data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']
      },
      yAxis: {},
      series: [
        {
          name: '销量',
          type: 'bar',
          data: [5, 20, 36, 10, 10, 20]
        }
      ]
    });
  }
}
</script>

--多系列柱状图

相比于基本柱状图,只需要多增加一列数据即可

html 复制代码
<!-- 基本柱状图 -->
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      title: {
        text: '多系列柱状图'
      },
      xAxis: {
        data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']
      },
      yAxis: {},
      series: [
        {
          name: '销量',
          type: 'bar',
          data: [5, 20, 36, 10, 10, 20]
        },
        {
          name: '销量',
          type: 'bar',
          data: [7, 10, 26, 30, 20, 30],
          itemStyle: {
            color: 'gold'
          }
        }
      ]
    });
  }
}
</script>

--堆叠柱状图

通过设置一个stack选项让其堆叠在一起,方便观察数据的变化。

html 复制代码
<!-- 基本柱状图 -->
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '堆叠柱状图'
      },
      xAxis: {
        data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']
      },
      yAxis: {},
      series: [
        {
          name: '销量',
          type: 'bar',
          data: [5, 20, 36, 10, 10, 20],
          stack:'x'
        },
        {
          name: '销量增量',
          type: 'bar',
          data: [2, 3, 6, 0, 10, 5],
          itemStyle: {
            color: 'gold'
          },
          stack:'x'
        }
      ]
    });
  }
}
</script>

使用 EChart 实现堆叠柱状图的方法非常简单,只需要给一个系列的 stack 值设置一个字符串类型的值,这一个值表示该系列堆叠的类别。也就是说,拥有同样 stack 值的系列将堆叠在一组。


--动态排序柱状图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '动态排序柱状图'
      },
      xAxis: {
        max: 'dataMax'
      },
      yAxis: {
        type: 'category',
        data: ['A', 'B', 'C', 'D', 'E','F'],
        inverse: true,
        animationDuration: 300,
        animationDurationUpdate: 300,
        // 设置柱状图最大显示数量从0开始
        max: 3 
      },
      series: [
        {
          realtimeSort: true,
          name: '销量',
          type: 'bar',
          data: [5, 20, 36, 10, 25, 10],
        
        },
      ]
    });
  }
}
</script>
  1. 柱状图系列的 realtimeSort 设为 true,表示开启该系列的动态排序效果
  2. yAxis.inverse 设为 true,表示 Y 轴从下往上是从小到大的排列
  3. yAxis.animationDuration 建议设为 300,表示第一次柱条排序动画的时长
  4. yAxis.animationDurationUpdate 建议设为 300,表示第一次后柱条排序动画的时长
  5. 如果想只显示前 n 名,将 yAxis.max 设为 n - 1,否则显示所有柱条
  6. xAxis.max 建议设为 'dataMax' 表示用数据的最大值作为 X 轴最大值,视觉效果更好
  7. 如果想要实时改变标签,需要将 series.label.valueAnimation 设为 true
  8. animationDuration 设为 0,表示第一份数据不需要从 0 开始动画(如果希望从 0 开始则设为和 animationDurationUpdate 相同的值)
  9. animationDurationUpdate 建议设为 3000 表示每次更新动画时长,这一数值应与调用 setOption 改变数据的频率相同
  10. animationDurationUpdate 的频率调用 setInterval,更新数据值,显示下一个时间点对应的柱条排序

3.2 折线图(type:'line')

--基本折线图
html 复制代码
<!-- 折线图 -->
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '销量基本折线图'
      },
      xAxis: {
        data: ['8-2', '8-3', '8-4', '8-5', '8-6', '8-7'],
      },
      yAxis: {},
      series: [
        {
          name: '销量',
          type: 'line',
          data: [5, 20, 36, 10, 10, 20]
        },
      ]
    });
  }
}
</script>

--多系列折线图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '多系列折线图'
      },
      xAxis: {
        data: ['8-2', '8-3', '8-4', '8-5', '8-6', '8-7'],
      },
      yAxis: {
      },
      series: [
        {
          name: '销量',
          type: 'line',
          data: [5, 20, 36, 10, 25, 10],
          
        },
        {
          name: '销量',
          type: 'line',
          data: [3, 10, 6, 4, 5, 12],
          itemStyle: {
            color: 'red'
          }
        },
      ]
    });
  }
}
</script>

--堆叠折线图

与堆叠柱状图类似都是加入stack,但是注意为了区分多系列折线图,一般建议使用区域填充色以表明堆叠的情况。

html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '堆叠折线图'
      },
      xAxis: {
        data: ['8-2', '8-3', '8-4', '8-5', '8-6', '8-7'],
      },
      yAxis: {
      },
      series: [
        {
          name: '销量',
          type: 'line',
          data: [5, 20, 36, 10, 25, 10],
          stack:'x',
          areaStyle: {}
        },
        {
          name: '销量增量',
          type: 'line',
          data: [3, 10, 6, 0, 5, 12],
          stack:'x',
          areaStyle: {}
        },
      ]
    });
  }
}
</script>

--平滑曲线图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '平滑曲线图'
      },
      xAxis: {
        data: ['8-2', '8-3', '8-4', '8-5', '8-6', '8-7'],
      },
      yAxis: {
      },
      series: [
        {
          name: '销量',
          type: 'line',
          data: [5, 20, 36, 10, 25, 10],
          smooth: true
        },
      
      ]
    });
  }
}
</script>

--阶梯折线图

在 ECharts 中,系列的 step 属性用来表征阶梯线图的连接类型,它共有三种取值:'start''middle''end',分别表示在当前点,当前点与下个点的中间点,下个点拐弯。


3.3 饼图(type:'pie')

--基本饼图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '基本饼图'
      },
    
      series: [
        {
          name: '总消费',
          type: 'pie',
          data: [
            {
              value: 324,
              name: '电子产品'
            },
            {
              value: 234,
              name:'食品'
            },{
              value: 154,
              name:'生活用品'
            },
            {
              value: 1048,
              name:'其他'
            }
        ],
        },
      
      ]
    });
  }
}
</script>

--圆环图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '圆环图'
      },
      series: [
        {
          name: '总消费',
          type: 'pie',
          data: [
            {
              value: 324,
              name: '电子产品'
            },
            {
              value: 234,
              name:'食品'
            },{
              value: 154,
              name:'生活用品'
            },
            {
              value: 1048,
              name:'其他'
            }
        ],
        radius: ['40%', '70%']
        },
      ]
    });
  }
}
</script>

--玫瑰图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '玫瑰图'
      },
      series: [
        {
          name: '总消费',
          type: 'pie',
          data: [
            {
              value: 324,
              name: '电子产品'
            },
            {
              value: 234,
              name:'食品'
            },{
              value: 154,
              name:'生活用品'
            },
            {
              value: 1048,
              name:'其他'
            }
        ],
         roseType: 'area'
        },
      ]
    });
  }
}
</script>

3.4 散点图(type:'scatter')

--基本散点图
html 复制代码
<template>
  <div id="app">
    <div id="main" style="width: 600px;height:400px;"></div>
  </div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  name: 'App',
  mounted() {
    // 基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'));

    // 绘制图表
    myChart.setOption({
      tooltip: {},
      title: {
        text: '基本散点图'
      },
      xAxis: {
        data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
      },
      yAxis: {},

      series: [
        {
         type:'scatter',
         data: [220, 182, 191, 234, 290, 330, 310]
        },
      ]
    });
  }
}
</script>

相关推荐
小彭努力中3 分钟前
64.在Vue3中使用OpenLayers显示带箭头的线段,箭头居中
前端·javascript·vue.js·arcgis·openlayers
我是哈哈hh6 分钟前
【javascript】Web APIs-Dom获取&属性操作
开发语言·前端·javascript·css·html
02苏_19 分钟前
2025/1/12 复习JS
开发语言·前端·javascript
小丑西瓜6661 小时前
Vue如何构建项目
前端·javascript·vue.js·前端框架
松堂飞萤1 小时前
Web开发(一)HTML5
前端·html·html5
初遇你时动了情2 小时前
vue3 uniapp封装一个瀑布流组件
前端·javascript·uni-app
初遇你时动了情2 小时前
react Hooks 父组件调用子组件函数、获取子组件属性
前端·javascript·react.js
ZoeLandia2 小时前
从前端视角看设计模式之创建型模式篇
前端·javascript·设计模式
林涧泣2 小时前
【Uniapp-Vue3】manifest.json配置
前端·vue.js·uni-app
真想骂*2 小时前
自然语言处理(NLP)在语音控制前端应用中的架构、发展与未来趋势
前端·人工智能·自然语言处理