0

0

Vue 数据表格无法连接数据库:解决“未找到结果”错误的完整教程

霞舞

霞舞

发布时间:2026-01-15 12:21:12

|

786人浏览过

|

来源于php中文网

原创

Vue 数据表格无法连接数据库:解决“未找到结果”错误的完整教程

本文详解 vue + vuetify 数据表格显示“your search for '{{ search }}' found no results”的根本原因——并非数据库连接失败,而是前端 `v-data-table` 的 `slot="no-results"` 被强制始终显示,需动态绑定其可见性,并确保后端数据正确返回与前端正确接收。

在使用 Vuetify 的 时,出现 “Your search for {{ search }} found no results” 提示,并不意味着数据库连接失败或后端无数据,而极大概率是前端组件逻辑配置问题:slot="no-results" 的 :value 属性被硬编码为 true,导致该提示无论数据是否存在都会强制显示

你当前的模板中存在关键错误:


  Your search for "{{ search }}" found no results.

✅ 正确做法是:将 :value 绑定到一个能反映真实数据状态的响应式变量,例如 Report.length === 0 —— 仅当 Report 数组为空(即未加载数据、加载失败或查询结果为空)时才显示提示。

✅ 正确配置 no-results 插槽


  

  
  
    Your search for "{{ search }}" found no results.
  
⚠️ 注意:Vuetify 2.x 中 slot="items" 和 slot="no-results" 已被 v-slot: 语法替代(如上例所示),建议升级写法以保证兼容性与可维护性。

? 同时排查真实的数据流问题

虽然 no-results 显示是前端配置问题,但若 Report 始终为空,则需检查完整链路:

聚蜂消防BeesFPD
聚蜂消防BeesFPD

关注消防领域的智慧云平台

下载

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

  1. 后端接口是否正常返回数据?
    浏览器开发者工具 → Network 标签中,检查 getReport(ts) 触发的请求(如 GET /api/report?endDate=...):

    • HTTP 状态码是否为 200?
    • 响应体是否为合法 JSON 数组(如 [{"col1":"A","col2":"B"},...])?
    • 是否存在 CORS、500 错误或空响应?
  2. Vue 方法中是否正确赋值?
    确保 getReport() 方法内通过 axios 或 fetch 获取数据后,正确更新 this.Report

    methods: {
      getReport(ts) {
        axios.get(`/api/balance-report?end_date=${this.endDate}`)
          .then(res => {
            // ✅ 关键:确保后端返回的是数组,且结构匹配 headers 的 value 字段
            this.Report = Array.isArray(res.data) ? res.data : [];
          })
          .catch(err => {
            console.error('Failed to load report:', err);
            this.Report = []; // 显式清空,触发 no-results 显示
          });
      }
    }
  3. 数据库连接类本身无直接问题,但建议增强健壮性
    你的 Database::db() 方法虽能连接,但缺少字符集声明,可能导致中文乱码或隐式失败。推荐补充 charset=utf8mb4:

    $db = "mysql:host=$host;dbname=$dbName;charset=utf8mb4";
    $pdo = new PDO($db, $userName, $password, [
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
        PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    ]);

✅ 最佳实践总结

项目 推荐做法
no-results 显示逻辑 使用 :value="Report.length === 0" 动态控制,禁用硬编码 true
headers.value 字段 确保与后端返回的 key 完全一致(注意空格!你代码中 'col1 ' 多了一个空格 → 应为 'col1')
初始数据状态 data() 中设 Report: [](空数组),而非 [] 或 null,避免 length 访问异常
错误调试 在 getReport() 中添加 console.log(res.data),确认数据结构与预期一致
Vuetify 版本适配 若使用 Vuetify ≥ 2.3,请统一使用 v-slot:items 替代已废弃的 slot="items"

修复后,表格将:

  • 数据加载成功 → 正常渲染;
  • 请求失败或返回空数组 → 显示“未找到结果”;
  • 搜索无匹配项 → 仍显示搜索提示(这是 :search 的默认行为,属正常)。

从此告别“假性数据库错误”,让问题定位回归真实链路。

相关专题

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

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

411

2023.08.07

json是什么
json是什么

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

532

2023.08.23

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

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

309

2023.10.13

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

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

74

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

436

2024.03.01

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

534

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 793人学习

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

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