0

0

如何正确构建JSON数据以在PrimeVue DataTable中显示

DDD

DDD

发布时间:2025-10-04 17:37:01

|

597人浏览过

|

来源于php中文网

原创

如何正确构建json数据以在primevue datatable中显示

本文旨在解决PrimeVue DataTable因后端返回的JSON数据格式不正确(数组嵌套数组而非对象数组)而无法显示数据的问题。我们将深入分析问题根源,并提供详细的Java后端解决方案,确保REST服务能输出符合前端期望的标准JSON格式,从而使数据在PrimeVue组件中正常渲染。

1. 问题背景与分析

在使用PrimeVue的DataTable组件时,开发者可能会遇到数据行显示为空白的问题。这通常不是前端组件本身的错误,而是因为从后端API获取的数据格式与DataTable期望的格式不符。

1.1 错误的数据格式示例

原始JSON数据(问题中提到的 "Json I get"):

[
   [
    32,
    "DE BELLOUET Jag",
    "1.3.13.3.",
    "Cid polseruti sau"
   ],
   [
    15,
    "NOURAUD Benjamin",
    "1.3.13.3.",
    "Cid polseruti sau"
   ]
]

这种格式是一个数组,其中每个元素又是一个数组。每个内部数组包含了一系列值,但没有明确的键(key)来标识这些值的含义。

1.2 期望的数据格式示例

PrimeVue DataTable以及大多数前端表格组件期望的数据格式是“对象数组”(问题中提到的 "Json I need" 的修正版):

立即学习前端免费学习笔记(深入)”;

[
   {
    "id":32,
    "fullName":"DE BELLOUET Jag",
    "acs":"1.3.13.3.",
    "nom_service":"Cid polseruti sau"
   },
   {
    "id":15,
    "fullName":"NOURAUD Benjamin",
    "acs":"1.3.13.3.",
    "nom_service":"Cid polseruti sau"
   }
]

这种格式同样是一个数组,但其每个元素是一个JSON对象。每个对象内部包含键值对,其中键(如"id"、"fullName")明确标识了对应值的含义。PrimeVue DataTable的正是通过这些键来绑定并显示数据的。

当后端返回的数据是数组嵌套数组时,前端的DataTable无法识别field="id"、field="fullName"等属性,因为这些属性在内部数组中并不存在,导致数据行显示为空。

2. 解决方案:优化Java后端REST服务

问题的核心在于Java后端REST服务如何将数据库查询结果序列化为JSON。当JPA查询不明确指定返回类型或使用投影时,getResultList()可能会返回List,而JAX-RS(如Resteasy与Jackson2)在序列化List时,默认会将其处理为数组的数组,而不是对象数组。

要解决此问题,我们需要修改AgentDAOImpl.java中的listAgentService方法,确保它返回List,并且每个AgentServ对象都正确地填充了数据。最优雅的方式是在JPQL查询中使用构造器表达式(Constructor Expression)。

免费语音克隆
免费语音克隆

这是一个提供免费语音克隆服务的平台,用户只需上传或录制一段 5 秒以上的清晰语音样本,平台即可生成与用户声音高度一致的 AI 语音克隆。

下载

2.1 修正 AgentDAOImpl.java

在fr.gouv.finances.douane.cotes.dao.agent.AgentDAOImpl类中,将listAgentService方法修改为使用JPQL的SELECT NEW语法。这会指示JPA直接将查询结果映射到AgentServ对象的构造函数。

// fr.gouv.finances.douane.cotes.dao.agent.AgentDAOImpl.java

import fr.gouv.finances.douane.cotes.dao.agent.AgentServ; // 确保导入 AgentServ

// ... 其他代码 ...

@SuppressWarnings("unchecked")
public List<AgentServ> listAgentService() {
    // 使用JPQL的SELECT NEW语法,直接将查询结果映射到AgentServ的构造函数
    // 这里的fr.gouv.finances.douane.cotes.dao.agent.AgentServ必须是完整的类名
    String jpql = "SELECT NEW fr.gouv.finances.douane.cotes.dao.agent.AgentServ(" +
                  "a.id, " +
                  "(btrim(a.nom) || ' ' || btrim(a.prenom)), " + // fullName
                  "s.acs, " + // acs
                  "s.libelle) " + // nom_service
                  "FROM Agent a INNER JOIN Service s ON a.service = s " + // 假设a.service是Service实体
                  "WHERE ((a.actif = true) OR ((a.actif = false) AND (a.dateSuppression >= CURRENT_DATE)))";

    // 执行查询并直接返回List<AgentServ>
    List<AgentServ> agents = em.createQuery(jpql, AgentServ.class).getResultList();

    return agents;
}

解释:

  • SELECT NEW fr.gouv.finances.douane.cotes.dao.agent.AgentServ(...):这是JPQL的构造器表达式语法。它告诉JPA,对于查询的每一行结果,都应该调用AgentServ类的对应构造函数来创建一个新的AgentServ实例。
  • 构造函数参数顺序:a.id, (btrim(a.nom) || ' ' || btrim(a.prenom)), s.acs, s.libelle 必须与 AgentServ 类中定义的 public AgentServ(long id, String fullName, String acs, String nom_service) 构造函数的参数顺序和类型严格匹配。
  • em.createQuery(jpql, AgentServ.class):在这里指定了查询的预期结果类型为AgentServ.class,增加了类型安全性。

2.2 AgentServ DTO类(确认)

确保AgentServ类是一个标准的Java Bean(POJO),拥有私有属性、公共的无参构造函数、以及对应的getter和setter方法。问题中提供的AgentServ类已经符合这个要求。

// fr.gouv.finances.douane.cotes.dao.agent.AgentServ.java
package fr.gouv.finances.douane.cotes.dao.agent;

public class AgentServ {
    private long id;
    private String fullName;
    private String acs;
    private String nom_service;

    public AgentServ() { /* 无参构造函数 */ }

    public AgentServ(long id, String fullName, String acs, String nom_service) {
        this.id = id;
        this.fullName = fullName;
        this.acs = acs;
        this.nom_service = nom_service;
    }

    // Getters and Setters for all fields
    public long getId() { return id; }
    public void setId(long id) { this.id = id; }
    public String getFullName() { return fullName; }
    public void setFullName(String fullName) { this.fullName = fullName; }
    public String getAcs() { return acs; }
    public void setAcs(String acs) { this.acs = acs; }
    public String getNom_service() { return nom_service; }
    public void setNom_service(String nom_service) { this.nom_service = nom_service; }
}

2.3 REST服务 AgentResourceRESTService.java

AgentResourceRESTService中的ListAgentService方法无需修改,因为它已经正确地声明了返回类型为List。一旦AgentDAOImpl中的listAgentService方法返回了正确的List对象,JAX-RS(通过resteasy-jackson2-provider)将自动将其序列化为期望的JSON对象数组格式。

// fr.gouv.finances.douane.cotes.rest.agent.AgentResourceRESTService.java

// ... 其他代码 ...

@Path("/agent")
@RequestScoped
public class AgentResourceRESTService {

    // ... 注入和其他方法 ...

    @GET
    @Path("/agentServ")
    @Produces("application/json; charset=UTF-8")
    public List<AgentServ> ListAgentService() {
        // 这里repository.listAgentService()现在会返回List<AgentServ>
        // Resteasy-Jackson2-provider会自动将其序列化为[{"id":..., "fullName":...}, ...]
        return repository.listAgentService();
    }
}

3. 前端 PrimeVue DataTable 配置

一旦后端开始提供正确的JSON格式,前端的PrimeVue DataTable代码应该能够正常工作,无需进行任何修改。

gererPersonnes.vue中的DataTable配置:

<DataTable :value="agents" :paginator="true" :rows="10" class="tableau">
    <template #empty>
        Pas d'agent trouvé.
    </template>
    <Column field="id" :sortable="true" header="Id" headerStyle="width: 3em" bodyStyle="text-align: center"></Column>
    <Column field="fullName" :sortable="true" header="Nom - Prénom" headerStyle="width: 250px"></Column>
    <Column field="service.acs" :sortable="true" header="A.C.S." headerStyle="width: 150px"></Column>
    <Column field="service.nom_service" :sortable="true" header="Service" headerStyle="width: 250px; text-aling: left;"></Column>
    <!-- ... 其他列和操作按钮 ... -->
</DataTable>

这里的field="id"、field="fullName"等属性会直接匹配后端返回JSON对象中的键,从而正确地显示数据。

4. 注意事项与最佳实践

  • 调试JSON响应: 在开发过程中,始终使用浏览器的开发者工具(Network/网络标签页)来检查后端API的实际JSON响应。这能帮助你快速确认后端是否已经返回了期望的格式。
  • DTO (Data Transfer Object): AgentServ类是一个很好的DTO示例。使用DTOs来封装特定于视图或API响应的数据,可以避免暴露完整的JPA实体,从而提高安全性、解耦性和性能。
  • JPQL SELECT NEW: 这是将查询结果直接映射到自定义对象(DTO)的标准且推荐方式,尤其是在查询结果不是单个实体时。
  • Jackson配置: resteasy-jackson2-provider依赖已在pom.xml中,这表明Resteasy会使用Jackson库进行JSON序列化。Jackson默认情况下会正确处理POJO列表到JSON对象数组的转换。
  • 数据模型匹配: 确保前端组件的field属性与后端JSON对象中的键名完全匹配(包括大小写)。

总结

解决PrimeVue DataTable不显示数据的问题,关键在于确保后端REST服务提供符合前端期望的JSON格式。通过在Java后端使用JPQL的SELECT NEW构造器表达式,我们可以精确地控制数据库查询结果如何映射到DTO对象,进而被JAX-RS序列化为标准的JSON对象数组。一旦后端数据格式正确,前端PrimeVue组件将能够无缝地渲染数据,提供用户友好的界面。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

455

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1946

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1168

2024.11.28

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 9.5万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号