Avue-data数据大屏显示饼图(附Demo)

目录

  • 前言
  • [1. Sql查询](#1. Sql查询)
  • [2. 颜色细节](#2. 颜色细节)

前言

对于这部分知识,原先有过柱状图实战:Avue-data数据大屏显示柱状图(附Demo讲解)

以下直奔主题,以Sql数据库数据为主

1. Sql查询

以饼图为例,需要返回的形式如下:

sql 复制代码
[
    {
        "name": "周口",
        "value": 55
    },
    {
        "name": "南阳",
        "value": 120
    },
    {
        "name": "西峡",
        "value": 78
    },
    {
        "name": "驻马店",
        "value": 66
    }
]

对应响应的数据需要接收name以及value

对应查询出来的数据如下:

饼图多数以单值的形式进行存储

对应需要配置成我们需要返回的响应数据

其过滤器规则如下:(根据自身的规则去除不需要的字段值)

js 复制代码
(data) => {
   const { ID, GDate, etltime, ...rest } = data[0]; // 解构去除不需要的字段
   return Object.entries(rest).map(([name, value]) => ({
       name,
       value
   }));
};

截图如下:

最终的成效图如下:(按照设定的时间进行动态跳转)

2. 颜色细节

对于更改颜色等细节变化

不可直接在过滤器中修改,无法生效

下述Demo错误:

javascript 复制代码
(data) => {
    const colorMap = {
        "A": "red",
        "B": "green",
        "C": "blue",
        "D": "orange",
        "E": "purple",
        "F": "cyan",
        "G": "magenta"
    };

    // 解构去除不需要的字段
    const { ID, GDate, etltime, ...rest } = data[0]; 

    // 创建数据项数组
    const formattedData = Object.entries(rest).map(([name, value]) => ({
        name,
        value
    }));

    // 创建颜色数组
    const colors = Object.keys(rest).map(name => colorMap[name] || "defaultColor");

    return {
        data: formattedData,
        color: colors,
        unit: '单位'
    };
};

此处的过滤器只有data数值,不应该返回任何颜色的属性

保持原先代码:

javascript 复制代码
(data) => {
   const { ID, GDate, etltime, ...rest } = data[0]; // 解构去除不需要的字段
   return Object.entries(rest).map(([name, value]) => ({
       name,
       value
   }));
};

修改颜色的配置位于此处:

对应的颜色配置如下:

javascript 复制代码
(data)=>{
  return {
    config:{
      radius: '40%',
      activeRadius: '45%',
      data: data,
      color : [
        '#e062ae', // 粉红色
        '#fb7293', // 玫瑰红
        '#e690d1', // 浅粉色
        '#32c5e9', // 天蓝色
        '#96bfff', // 浅蓝色
        '#9e62ae', // 紫红色
        '#7f62ae'  // 紫色
      ],
      digitalFlopStyle: {
        fontSize: 20
      },
      showOriginValue: true
    }
  }
}

结果如下:

相关推荐
huihui450几秒前
一天一道Sql题(day01)
数据库
~尼卡~2 分钟前
软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制
数据库·软件设计师-软考
八九燕来10 分钟前
Django双下划线查询
数据库·django·sqlite
眠りたいです43 分钟前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql
paopaokaka_luck1 小时前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序
He.ZaoCha2 小时前
函数-1-字符串函数
数据库·sql·mysql
二当家的素材网2 小时前
Centos和麒麟系统如何每天晚上2点10分定时备份达梦数据库
linux·数据库·centos
白仑色2 小时前
Oracle 存储过程、函数与触发器
数据库·oracle·数据库开发·存储过程·plsql编程
头发那是一根不剩了3 小时前
Spring Boot 多数据源切换:AbstractRoutingDataSource
数据库·spring boot·后端
草履虫建模4 小时前
Redis:高性能内存数据库与缓存利器
java·数据库·spring boot·redis·分布式·mysql·缓存