Vue3+Echarts:堆积柱状图的绘制
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
一、需求
- 在Vue3项目中,想用Echarts来绘制堆积柱状图,去展示最近一周APP在不同渠道的登录人数
- 效果如下:
二、实现
(关于Echarts的下载安装以及图表的样式设计,此处不展开!)
1、Templates部分
<template>
<div class="login">
<div class="chart" id="bar"></div>
</div>
</template>
2、Script部分
(1)总体逻辑
(2)图表数据
图表想要展示的指标是:最近一周APP在不同渠道的登陆人数,包括ios端、android端、网页端
- 使用ref来声明数据:
const dataAll = ref();
- 数据格式如下:
dataAll.value = [
{
id: 1,
option1: "登录人数",
data: [
[12000, 13200, 10100, 13400, 9000, 23000, 21000],
[22000, 18200, 19100, 23400, 29000, 33000, 31000],
[22000, 18200, 19100, 23400, 29000, 33000, 31000],
],
}
];
-
echarts核心代码
- 每个柱子包含三部分的数据,分别是android端的登录人数、ios端的登录人数以及pc端的登录人数;
- 因此series包含三个对象,分别代表三个渠道;
- 每个对象里面是每个渠道最近7天的登录人数
- echarts部分的完整代码:
onMounted(() => {
let myChart = $echarts.init(document.getElementById("bar"));
myChart.setOption({
color: ["#f88c68", "#688CF8", "#68D4F8", "#8C68F8"],
// 图表标题
title: {
text: "APP登录",
textStyle: {
//文字样式
color: "#fff",
fontSize: 15,
},
// 标题位置
left: 0,
top: 0,
},
// 网格grid:控制直角坐标系的布局和大小
grid: {
left: "12%",
right: "12%",
bottom: "10%",
// containLabel: true
},
// 提示框
tooltip: {
trigger: "axis",
axisPointer: {
// 坐标轴指示器,坐标轴触发有效
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
},
},
// 工具栏
toolbox: {
feature: {
saveAsImage: {}, //导出图片
},
},
xAxis: {
name: "日期", //x轴名称
type: "category",
data: ["12-9", "12-10", "12-11", "12-12", "12-13", "12-14", "12-15"],
// 去除刻度线
axisTick: {
alignWithLabel: true,
},
// 对横轴刻度标签进行处理
axisLabel: {
//修改坐标系字体颜色
// show: true,
textStyle: {
color: "#fff",
},
interval: 0,
margin: 10,
fontSize: "12",
},
axisLine: {
show: false,
},
},
yAxis: {
name: "人", //x轴名称
type: "value",
splitLine: {
show: false, //去掉折线图中的横线
},
// 去除刻度线
axisTick: {
show: false,
},
// 对横轴刻度标签进行处理
axisLabel: {
//修改坐标系字体颜色
show: true,
textStyle: {
color: "#fff",
},
interval: 0,
margin: 10,
},
},
series: [
{
name: "Android:",
type: "bar",
stack: "stack",
barWidth: "35%",
data: data.value[0],
},
{
name: "iOS:",
type: "bar",
stack: "stack",
barWidth: "35%",
data: data.value[1],
},
{
name: "Web:",
type: "bar",
stack: "stack",
barWidth: "35%",
data: data.value[2],
},
],
});
});
3、效果如下:
GitHub 加速计划 / vu / vue
82
16
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:4 个月前 )
9e887079
[skip ci] 2 个月前
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 6 个月前
更多推荐
已为社区贡献16条内容
所有评论(0)