解决 ECharts 图表无数据显示问题
问题:
在开发项目时,后端明明已经成功返回了数据,但在展示手账发布数量趋势和树洞帖子发布数量趋势的 ECharts 图表中,却只有坐标轴,没有任何数据显示。

以我的VUE项目开发可视化面板为例,下面将详细分析可能出现的情况以及对应的解决办法。
当后端有数据返回,但 ECharts 图表只有坐标轴而没有数据显示时,可能是由以下几个原因导致的,下面针对手账发布数量趋势和树洞帖子发布数量趋势的 ECharts 图表进行详细分析:
1. 数据处理问题
在 getArticlePostTrendData 和 getTreeholePostTrendData 函数中,可能存在数据处理不当的情况,导致 xAxis 和 yAxis 数据没有正确填充到 ECharts 选项中。
解决方案
检查 forEach 循环中对数据的处理是否正确,确保 createDate 能够正确匹配到 dates 数组中的日期。可以在关键位置添加 console.log 语句进行调试,例如:
// 获取手账发布数量趋势数据
const getArticlePostTrendData = async () => {try {const response = await articleByWeekService();const data = response.data;console.log('手账数据:', data);// 生成最近一周的日期数组const now = new Date();const oneWeekAgo = new Date(now.getTime() - 7 * 24 * 60 * 60 * 1000);const dates = [];for (let d = new Date(oneWeekAgo); d <= now; d.setDate(d.getDate() + 1)) {dates.push(new Date(d).toISOString().split('T')[0]);}// 初始化每天的新增手账数为 0const counts = new Array(7).fill(0);// 统计每天新增的手账数data.forEach(item => {const createDate = new Date(item.createTime).toISOString().split('T')[0];console.log('手账创建日期:', createDate);const index = dates.indexOf(createDate);if (index !== -1) {counts[index]++;}});articlePostTrendData.value.xAxis = dates;articlePostTrendData.value.yAxis = counts;console.log('手账 xAxis:', articlePostTrendData.value.xAxis);console.log('手账 yAxis:', articlePostTrendData.value.yAxis);initArticlePostTrendChart();} catch (error) {console.error('获取手账发布数量趋势数据时出错:', error);}
};// 获取树洞帖子发布数量趋势数据
const getTreeholePostTrendData = async () => {try {const response = await treeholebyweekService();const data = response.data;console.log('树洞数据:', data);// 生成最近一周的日期数组const now = new Date();const oneWeekAgo = new Date(now.getTime() - 7 * 24 * 60 * 60 * 1000);const dates = [];for (let d = new Date(oneWeekAgo); d <= now; d.setDate(d.getDate() + 1)) {dates.push(new Date(d).toISOString().split('T')[0]);}// 初始化每天的新增树洞帖子数为 0const counts = new Array(7).fill(0);// 统计每天新增的树洞帖子数data.forEach(item => {const createDate = new Date(item.createTime).toISOString().split('T')[0];console.log('树洞创建日期:', createDate);const index = dates.indexOf(createDate);if (index !== -1) {counts[index]++;}});treeholePostTrendData.value.xAxis = dates;treeholePostTrendData.value.yAxis = counts;console.log('树洞 xAxis:', treeholePostTrendData.value.xAxis);console.log('树洞 yAxis:', treeholePostTrendData.value.yAxis);initTreeholePostTrendChart();} catch (error) {console.error('获取树洞帖子发布数量趋势数据时出错:', error);}
};
检查一下:

说明数据处理没有问题
2. 异步数据加载问题
由于数据是异步获取的,可能在 ECharts 初始化时数据还未完全加载完成,导致图表没有正确显示数据。
解决方案
确保在数据加载完成后再初始化 ECharts 图表。可以使用 await 关键字确保数据加载完成后再调用初始化函数。
检查一下:

异步数据加载没有问题
3. ECharts 选项问题
在 initArticlePostTrendChart 和 initTreeholePostTrendChart 函数中,可能存在 ECharts 选项设置错误的情况。
解决方案
检查 xAxis 和 yAxis 的数据绑定是否正确,确保 data 属性指向正确的数组。例如:
const initArticlePostTrendChart = () => {const chartDom = document.getElementById('article-post-trend');const myChart = echarts.init(chartDom);const option = {title: {text: '手账发布数量趋势'},tooltip: {trigger: 'axis'},xAxis: {data: articlePostTrendData.value.xAxis // 确保使用 value 属性},yAxis: {type: 'value',integer: true},series: [{name: '手账数量',type: 'line',data: articlePostTrendData.value.yAxis // 确保使用 value 属性}]};myChart.setOption(option);
};const initTreeholePostTrendChart = () => {const chartDom = document.getElementById('treehole-post-trend');const myChart = echarts.init(chartDom);const option = {title: {text: '树洞帖子发布数量趋势'},tooltip: {trigger: 'axis'},xAxis: {data: treeholePostTrendData.value.xAxis // 确保使用 value 属性},yAxis: {type: 'value',integer: true},series: [{name: '树洞帖子数量',type: 'line',data: treeholePostTrendData.value.yAxis // 确保使用 value 属性}]};myChart.setOption(option);
};
检查一下:
发现确实是少了value属性

通过以上步骤,你可以逐步排查问题并解决 ECharts 图表没有数据显示的问题。
成功解决:

总结
当 ECharts 图表只有坐标轴但没有数据显示时,要从数据传递、数据格式、图表初始化时机和元素获取等方面进行检查。通过仔细排查,通常可以找到问题并解决。
相关文章:
解决 ECharts 图表无数据显示问题
问题: 在开发项目时,后端明明已经成功返回了数据,但在展示手账发布数量趋势和树洞帖子发布数量趋势的 ECharts 图表中,却只有坐标轴,没有任何数据显示。 以我的VUE项目开发可视化面板为例,下面将详细分析可…...
spacy安装失败报错
报错 使用命令pip install spacy安装spacy时总是报错(python -m pip install spacy方式安装同样报错) 解决办法 使用conda安装,conda能够避免很多不必要的依赖包。 命令:conda install spacy 安装成功列表展示...
C++在Linux上生成动态库并调用接口测试
加减乘除demo代码 项目结构 CPP/ ├── calculator.cpp ├── calculator.h ├── main.cpp 头文件 #ifndef CALCULATOR_H #define CALCULATOR_H#ifdef __cplusplus extern "C" {#endifdouble add(double a, double b);double subtract(double a, double b…...
第三篇:Python数据结构深度解析与工程实践
第一章:列表与字典 1.1 列表的工程级应用 1.1.1 动态数组实现机制 Python列表底层采用动态数组结构,初始分配8个元素空间,当空间不足时按0,4,8,16,25,35...的公式扩容,每次扩容增加约12.5%的容量 通过sys模块可验证扩容过程: import sys lst = [] prev_size = 0 for …...
前端性能测试工具 —— WebPageTest
测试工具介绍 WebPageTest 是一个用于测量和分析网页性能的工具。它提供了详细的诊断信息,帮助用户了解网页在不同条件下的表现。用户可以选择全球不同的测试地点,使用真实的浏览器,并自定义网络条件进行测试。WebPageTest 还支持核心网络指…...
北邮LLMs在导航中的应用与挑战!大模型在具身导航中的应用进展综述
作者:Jinzhou Lin, Han Gao, Xuxiang Feng, Rongtao Xu, Changwei Wang, Man Zhang, Li Guo, Shibiao Xu 单位:北京邮电大学人工智能学院,中国科学院自动化研究所多模态人工智能系统国家重点实验室,中科院空间信息研究所…...
Windows下ElasticSearch8.x的安装步骤
下载ElasticSearch:https://www.elastic.co/downloads/elasticsearch (我下载的是目前最新版8.17.4)解压ElasticSearch 进入到ElasticSearch的bin目录下双击elasticsearch.bat 弹出控制台并开始执行,在这一步会输出初始账号和密码…...
【高性能缓存Redis_中间件】一、快速上手redis缓存中间件
一、铺垫 在当今的软件开发领域,消息队列扮演着至关重要的角色。它能够帮助我们实现系统的异步处理、流量削峰以及系统解耦等功能,从而提升系统的性能和可维护性。Redis 作为一款高性能的键值对数据库,不仅提供了丰富的数据结构,…...
AI Agent入门指南
图片来源网络 一、开箱暴击:你以为的"智障音箱",其实是赛博世界的007 1.1 从人工智障到智能叛逃:Agent进化史堪比《甄嬛传》 青铜时代(2006-2015) “小娜同学,关灯” “抱歉&…...
React 第三十节 使用 useState 和 useEffect Hook实现购物车
不使用 redux 实现 购物车案例 使用 React 自带的 useState 和 useEffect Hook 即可实现购物车 export default function ShoppingCar() {// 要结算的商品 总数 以及总价const [totalNum, setTotalNum] useState(0)const [totalPerice, setTotalPerice] useState(0)// 商品…...
Git的简介和简单的命令使用介绍
Git 是一种分布式版本控制系统,常用于跟踪文件的变化,协作开发和管理代码版本。以下是 Git 的基本概念和使用方式: 仓库(Repository):Git 仓库是用来存储项目文件和版本历史的地方。可以通过在本地或远程创…...
概念辨析:Redis 多路 I/O 复用和多线程
Redis 多路 I/O 复用是在 Redis 2.0 引入的,而 Redis 多线程是在 Redis 6.0 引入的,两者不是同一个概念。 多路复用的本质还是同步 I/O,因为最终都需要主线程调用 read() 方法把数据拷贝到用户态。 在并发量非常大的情况下,Redi…...
海洋大地测量基准与水下导航系列之八我国海洋水下定位装备发展现状
中国国家综合PNT体系建设重点可概括为“51N”,“5”指5大基础设施,包括重点推进下一代北斗卫星导航系统、积极发展低轨导航增强系统、按需发展水下导航系统、大力发展惯性导航系统、积极探索脉冲星导航系统;“1”是实现1个融合发展࿰…...
计算机系统设计中的一些常用方法
面试中经常被问到: 有一个亿qq号,找出重复的 给你512m内存,找出5g文件中最大的数字 订单超时实现精准关单 … 当然,还有经常遇到的问题: 接口业务逻辑复杂或查数据库慢,相应耗时高 网络因为丢包导致服…...
【征程 6】工具链 VP 示例中 Cmakelists 解读
1. 引言 在文章【征程 6】VP 简介与单算子实操中,介绍了 VP 是什么,并以单算子 rotate 为例,介绍了 VP API 使用方法。在【征程 6】工具链 VP 示例中日志打印解读 中介绍了 VP 单算子示例中用到的日志打印的头文件应该怎么写。接下来和大家一…...
深入解析 Jenkins Agent 的 .jnlp 启动文件
🧩 深入解析 Jenkins Agent 的 .jnlp 启动文件 在 Jenkins 中,通过 JNLP(Java Network Launch Protocol)方式连接 Agent 是一种常见且灵活的方式。你可能曾见过类似这样的命令: java -jar agent.jar -jnlpUrl file:/…...
谷歌开源代理开发工具包(Agent Development Kit,ADK):让多智能体应用的构建变得更简
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
0x01、Redis 主从复制的实现原理是什么?
Redis 主从复制概述 Redis 的主从复制是一种机制,允许一个主节点(主实例)将数据复制到一个或多个从节点(从实例)。通过这一机制,从节点可以获取主节点的数据并与之保持同步。 复制流程 开始同步…...
noscript 标签是干什么的
vue public目录下的 index.html 会有 <noscript> 标签不知道是干吗的。 其实 noscript 标签在不支持或是禁用JavaScript 的浏览器中显示替代的内容。这个元素可以包含任何 HTML 元素。这个标签的用法也非常简单: <noscript><strong>Were sorry …...
[创业之路-366]:投资尽职调查 - 尽调核心逻辑与核心影响因素:价值、估值、退出、风险、策略
目录 一、VC投资的本质是冒着不确定性风险进行买卖、生意,为了赚取高额回报 1、VC投资的核心本质 2、VC投资的运作机制 3、VC投资的风险与挑战 4、VC投资的底层逻辑 5、总结:VC投资的本质再定义 二、尽调核心逻辑 1、尽调的含义 2、尽调的逻辑方…...
MOP数据库中的EXPLAIN用法
EXPLAIN 是 SQL 中的一个非常有用的工具,主要用于分析查询语句的执行计划。执行计划能展示数据库在执行查询时的具体操作步骤,像表的读取顺序、使用的索引情况、数据的访问方式等,这有助于我们对查询性能进行优化。 语法 不同的数据库系统&…...
Hyprnote开源程序是一款记录和转录您会议的 AI 记事本。 本地优先且可扩展 。
一、软件介绍 文末提供源码下载学习 Hyprnote开源程序是一款记录和转录您会议的 AI 记事本。 从您的原始会议记录中生成强大的摘要,本地优先且可扩展 。使用开源模型 (Whisper & Llama) 离线工作,高度可扩展 ,由插…...
MSCKF及可观性总结
可观性 参考链接 真实VIO系统不能观的维度是4(位置和yaw角),由于EKF的转移和观测Jacobian矩阵的线性化点不同、不可观方向噪声的存在,实际MSCKF不能观的维度变成了3,绕重力轴的旋转(yaw角)被错…...
上篇:新能源轻卡城配物流经济/动力模式量化定义(理论篇)——数学暴力破解工程困局
副标题:用微分方程撕开模式切换本质,用传感器数据重构载重真相 引言:为什么轻卡模式定义比乘用车难10倍? 行业现状痛点: 中国新能源轻卡日均载重波动高达300%(空载0kg→满载4.5吨)某头部车企实…...
Ubuntu22环境下,Docker部署阿里FunASR的gpu版本
番外: 随着deepseek的爆火,人工智能相关的开发变得异常火爆,相关的大模型开发很常见的agent智能体需要ASR语音识别的功能,阿里开源的FunASR几乎是把一个商业的项目放给我们使用了。那么我们项目中的生产环境怎么部署gpu版本的语音识别服务呢?经过跟deepseek的一上午的极限…...
Python 实现最小插件框架
文章目录 Python 实现最小插件框架1. 基础实现项目结构plugin_base.py - 插件基类plugins/hello.py - 示例插件1plugins/goodbye.py - 示例插件2main.py - 主程序 2. 更高级的特性扩展2.1 插件配置支持2.2 插件依赖管理2.3 插件热加载 3. 使用 setuptools 的入口点发现插件3.1 …...
内网邮箱服务器搭建-详解
目录 一、背景 二、搭建邮箱需要具备的基础知识 1、smtp(Simple Mail Transfer Protocol) SMTP工作原理 SMTP 命令 SMTP 协议端口 2、pop3(Post Office Protocol) POP3特点 POP3工作原理 3、imap4(Internet M…...
21 天 Python 计划:使用SQLAlchemy 中的ORM查询
文章目录 准备工作图书表 books分类表 categoriesORM 对象定义 一、根据主键获取记录二、AND 查询三、 常用方法四、OR 查询五、 5. AND 和 OR 并存的查询六、巧用列表或者字典的解包给查询方法传参七、其它常用运算符八、查询指定列九、内连接、外连接9.1 内连接9.2 外连接9.3…...
使用 LLaMA-Factory 微调 llama3 模型(二)
使用 LLaMA-Factory 微调 llama3 模型 1. LLaMA-Factory模型介绍 https://github.com/hiyouga/LLaMA-FactoryLLaMA-Factory 是一个用于大型语言模型(LLM)微调的工具,它旨在简化大型语言模型的微调过程, 使得用户可以快速地对模型…...
并发编程--条件量与死锁及其解决方案
并发编程–条件量与死锁及其解决方案 文章目录 并发编程--条件量与死锁及其解决方案1.条件量1.1条件量基本概念1.2条件量的使用 2. 死锁 1.条件量 1.1条件量基本概念 在许多场合中,程序的执行通常需要满足一定的条件,条件不成熟的时候,任务…...
