官网
https://echarts.apache.org/zh/index.html
安装使用
# 安装
npm i echarts
yarn add echarts
# 组件使用时引入
import * as echarts from 'echarts'
使用方式
// 放在DOM加载完成后
onMounted(() => {
// 解决路由跳转不显示问题
echarts.dispose(document.getElementById('main1'))
// 基于准备好的dom,初始化echarts实例
let myChart = echarts.init(document.getElementById('main1'));
// 绘制图表
myChart.setOption({
title: {
text: '报告来源'
},
tooltip: {},
xAxis: {
data: ['国家\n\n机关', '村居\n\n两委', '教育类\n\n从业者', '医疗类\n\n从业者', '旅馆类\n\n从业者', '其他行\n\n业从业者'],
},
yAxis: [{
type: 'value',
//去掉背景区域
splitArea: {
show: false
},
// 去除背景线
splitLine: {
show: false
},
axisLine: { //设置y轴坐标线的样式
lineStyle: {
type: 'solid',
color: '#b8c2c1', //y轴坐标线的颜色
width: '1' //y轴坐标线的宽度
}
},
}],
series: [
{
name: '销量',
type: 'bar',
data: [5, 20, 36, 10, 10, 20]
}
]
});
})
自定义颜色
series: [
{
type: 'pie',
radius: ['40%', '70%'],
itemStyle: {
borderRadius: 2,
borderWidth: 4,
},
labelLine: {
show: false,
},
data: [
{ value: 1048, name: '男生' },
{ value: 735, name: '女生' },
],
// 自定义颜色
color: ['#1E90FF', '#FF69B4']
}
]
取消x轴刻度显示
xAxis: {
type: 'category',
data: ['06/06', '06/07', '06/08', '06/09', '06/10', '06/11', '06/12'],
axisTick: {
show: false, // 取消刻度
},
axisLine: {
lineStyle: {
type: 'solid',
color: '#b8c2c1',
width: '1',
},
},
},
label显示
label: {
show: true,
position: 'top',
color: '#9EC4ED',
fontSize: 12,
rotate: '90', // 旋转
offset: [10, 6], // 位置
},
区域面积渐变
series: [
{
data: [150, 230, 224, 218, 135, 147, 260],
type: 'line',
color: ['#1E90FF'],
areaStyle: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: 'rgba(58,132,255, 0.5)', // 0% 处的颜色
},
{
offset: 1,
color: 'rgba(58,132,255, 0)', // 100% 处的颜色
},
],
global: false, // 缺省为 false
},
},
},
],
图表边距调整
option:{
grid: {
left: '36px',
right: '0%',
top: '0px',
bottom: '0px',
},
}
数据处理(map)
// 数据结构
[
{
"data": "2023-10-08",
"count": 0
},
{
"data": "2023-10-09",
"count": 0
},
{
"data": "2023-10-10",
"count": 0
},
{
"data": "2023-10-11",
"count": 7
},
{
"data": "2023-10-12",
"count": 4
}
]
// 数据处理
const echartsX = list.map(function (item) {
return item.data
})
const echartsY = list.map(function (item) {
return item.count
})