vben admin BasicTable 表格的进阶使用之带搜索区域
创始人
2025-05-28 12:08:27
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 对象,而不是实例对象

相关内容

热门资讯

芯片股集体走强,华虹半导体盘中... 新京报贝壳财经讯 1月2日,港股芯片股集体走强,其中,华虹半导体盘中涨超9%,芯智控股盘中涨近5%,...
晓数点丨2025年十大牛股出炉... 2025年,沪指报收3968.84点,全年收涨18.41%,年内时隔十年重回4000点;创业板指全年...
复盘2025!公募基金四大痛点... 编者按:2025年,随着一系列改革举措加速落地见效,公募基金行业的高质量发展成色持续提升。岁末年初,...
斯基拉爆料:迈尼昂接近与米兰续... 新年伊始,对于AC米兰的球迷们来说,没有什么比听到主力门将迈尼昂即将续约的消息更令人振奋了。据知名记...
最新!美国对部分跨境汇款征收1... 据央视新闻,当地时间2026年1月1日,美国针对部分跨境汇款的新税收措施正式生效。根据美国财政部和美...
印度1亿烟民新年噩耗,香烟每千... 印度政府对香烟加征新税,导致该国烟草类股周四遭遇重挫,市场领军企业印度烟草公司ITC股价创近六年来最...
郭芙蓉欠的48两,放现在值多少... 关注混知财经并回复下方词条,就能找到你想知道的答案!
百度:拟分拆昆仑芯于港交所主板... 百度集团在港交所公告,1月1日,昆仑芯已透过其联席保荐人以保密形式向香港联交所提交上市申请表格(A1...
500ml飞天茅台正式上线i茅... 2025年12月31日,贵州茅台通过“i茅台”平台宣布,自2026年1月1日起,53度500ml飞天...
实探金银市场:“只剩300克以...   中新经纬1月1日电 (李自曼)“小克重的金条已经卖没了,只剩300克以上的。”2025年12月2...