Echarts 在Vue中的简单使用
? 简介
Echarts是百度整出来的一个开源的数据可视化工具,现已加入Apache基金会全家桶(雾
官网:echarts.apache.org
? 安装
可以通过yarn等包管理器安装Echarts
yarn add echarts -w
? 在Vue项目中引入
需要注意的是,V5版本以后引入Echarts的方式改变了,具体方式如下:
import * as echarts from "echarts";//全局引入
// 按需引入
//import * as echarts from 'echarts/lib/echarts';
V5版本以前引入方式如下:
import echarts from "echarts";
? 绘制图表
在绘制图表之前,我们需要了解Echarts编写图表的三大步骤:
- 指定一个HTML盒子,用于展示图表,一定要指定宽高,不然后面图表不显示在那找半天原因((
- 使用ref或者选择器获取DOM节点,使用
echarts.init()
进行初始化 - 使用
mychart.setOption(options)
进行图表的详细配置,options
是配置对象
具体代码如下:
<template>
<div class="charts" ref="charts"></div>
</template>
<script>
let mychart = echarts.init(this.$refs.charts);
mychart.setOption({
title: {
text: '数据可视化',
subtext: 'echarts的基本使用',
textStyle: {
color: '#66ccff'
},
left: 'center'
},
xAxis: {
data: ['唱', '跳', 'rap', '篮球']
},
yAxis: {
axisLine: {
show: true
},
axisTick: {
show: true
}
},
series: [
{
type: 'bar',
data: [1, 2, 3, 4],
color: 'pink',
}
]
});
</script>
参数解释:
title
:图表的标题text
:主标题textStyle
:主标题的颜色,为一个对象left
:标题相对于左边的位置xAxis
和yAxis
data
:数据,一般为数组series
:系列的设置(绘制什么样类型的图表,数据的展示在这里设置)axisTick
:显示y\x轴的刻度axisLine
:显示轴线type: 'bar'
:图表类型的设置{line是折线图,pie是饼图,bar是柱状图}
还有很多有意思的配置项,详细的话还是参考官方文档吧((
绘制出来的图长这样:
再画个饼图吧~
mychart.setOption({
title: {
text: "Video Ads",
subtext: "300",
left: "center",
top: "center",
},
tooltip: {
trigger: "item",
},
series: [
{
name: "Access From",
type: "pie",
radius: ["40%", "70%"],
avoidLabelOverlap: false,
itemStyle: {
borderRadius: 10,
borderColor: "#fff",
borderWidth: 2,
},
label: {
show: true,
position: "outside",
},
labelLine: {
show: true,
},
data: [
{ value: 1048, name: "Search" },
{ value: 735, name: "Direct" },
{ value: 580, name: "Email" },
{ value: 484, name: "Union Ads" },
{ value: 300, name: "Video Ads" },
],
},
],
});
//绑定事件
mychart.on("mouseover", function (params) {
const { name, value } = params.data;
this.setOption({
title: {
text:name,
subtext:value
},
});
});
你猜的没错,图表确实也可以绑定事件,当鼠标每次划过的时候就可以再圆心展示选中的标题
效果图:
当然还有其他样式的图,甚至可以画出一整个地球出来Σ(っ °Д °;)っ