vben admin BasicTable 表格的进阶使用之带搜索区域
创始人
2025-05-28 12:46:09
0

vben admin BasicTable 表格的进阶使用之带搜索区域

  • 前言
  • 一、上代码
  • 二、上最终效果
  • 三、代码分析
    • 1.创建实例
    • 2. 表格设置工具的配置
    • 2.使用 table 的插槽来放置按钮
    • 3.获取搜索区域表单的值
    • 4.实现在外部调用表单的 reload()
  • 遗留思考
  • 总结


前言

很久之前看了下关于 vben 的基础使用,最近项目需求开始用了,业务需要一个带搜索区域的表格,今天写完有点懵逼,来记录的过程中整理下思路~~

这里是之前写过的关于 vben admin BasicTable 表格的基本使用

一、上代码



二、上最终效果

在这里插入图片描述

三、代码分析

1.创建实例

我这里使用 useTable 的方式
如果需要开启搜索区域,在 useTable 的配置过程中需要加上下面的配置项

useSearchForm boolean false 使用搜索表单
formConfig any 表单配置,参考表单组件的 Props

在这里插入图片描述

2. 表格设置工具的配置

默认表格的设置区域的样式是这样子的,但是实际上并不需要这些,只保留一个刷新就可以了
在这里插入图片描述
配置项

showTableSetting	boolean	false	-	显示表格设置工具	
tableSetting	TableSetting	-	-	表格设置工具配置,见下方 TableSetting

在这里插入图片描述

2.使用 table 的插槽来放置按钮

在这里插入图片描述这里使用了 basic table 的插槽来实现的
在这里插入图片描述

        

3.获取搜索区域表单的值

业务需求,在点击数据导出按钮的时候,执行 exportData() 函数需要发请求获取对应的文件 url 地址来实现下载功能
但是这个请求是需要带表格搜索区域的时间条件作为参数的,所以我需要获取到搜索表单中的数据
在官方文档中可以看到,table 的 methods 中是有 getForm() 的
在这里插入图片描述在这里插入图片描述
在 exportData() 方法中,调用 getForm() 方法,获取到搜索表单实例对象
再调用 form 实例对象的getFieldsValue() 来获取数据

 let data = getForm().getFieldsValue();
  function exportData() {// getForm().resetFields()let data = getForm().getFieldsValue();exportTowerHistoryToExcel({ deviceId, createTime: data.startTime }).then((url) => {let fileName = url.slice(url.lastIndexOf('/') + 1);fetch(url).then((res) => res.blob()).then((blob) => {const link = document.createElement('a');link.href = URL.createObjectURL(blob);// 下载文件的名称及文件类型后缀link.download = fileName;document.body.appendChild(link);link.click();//在资源下载完成后 清除 占用的缓存资源window.URL.revokeObjectURL(link.href);document.body.removeChild(link);});});}

4.实现在外部调用表单的 reload()

业务表单需要在某些时机来刷新,而不是手动点击表单设置工具区域的刷新按钮,所以就需要表格实例对象的 reload() 方法
在这里插入图片描述

  const [registerTableA, { reload, getForm }] = useTable({.....});reload();

这样在需要刷新表单的时候执行 reload 就可以了


遗留思考

如果一个页面当中有多个表单实例的话 , emmm 分别需要在两个位置执行这两个表单的 reload()

如果出现下面的情况,怎样区分 是哪个表单的 relaod 呢?
(盲猜测以下代码会报错 毕竟出现了两个 reload 两个 getForm )

  const [registerTableA, { reload, getForm }] = useTable({.....});const [registerTableB, { reload, getForm }] = useTable({.....});

(继续猜测,没时间验证,等真的遇到可以试试看? 主要还是对 vue3 了解太差了)

  const [registerTableA, { reload as reloadA, getForm as getFormA }] = useTable({.....});const [registerTableB, { reload as reloadB, getForm  as getFormB }] = useTable({.....});reloadA();reloadB(); 

猜测失败

//直接编译失败了const [registerTableA, { reload as reloadA, getForm as getFormA }] = useTable({.....});const [registerTableB, { reload as reloadB, getForm  as getFormB }] = useTable({.....});reloadA();reloadB(); 
// reloadA is not definedconst [registerTableA, { reloadA :reload, getForm}] = useTable({.....});const [registerTableB, { reloadB :reload, getForm}] = useTable({.....});reloadA();reloadB(); 

总结

之前一直以为需要先通过给 table 或者 form 绑定 ref ,才能执行到 reload() , getFieldsValues() … 方法,但是实际上这种方式获取的好像是 DOM 对象,而不是实例对象

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...