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 对象,而不是实例对象

相关内容

热门资讯

原创 9... 最近,日本首相高市早苗声称正在推动美伊首脑会谈,这一消息迅速引起了国际社会的广泛关注。在日本国会的一...
道指再创盘中新高,日内涨幅0.... 8月19日消息,道指再创盘中新高,日内涨幅0.6%。(科股宝播报)
贵州:聚焦算力、数据、应用、产... 8月19日消息,据贵州发布,8月19日,全省数字经济发展推进大会在贵阳召开。省委书记徐麟出席并讲话,...
半两财经|先跌后涨重回4700... 4月6日,国际黄金市场先跌后涨。截至北京青年报记者发稿时,现货黄金与COMEX黄金期货纷纷站到470...
“国产数据库第一股”达梦数据总... 8月19日消息,武汉达梦数据库股份有限公司(以下称:达梦数据)公告称,公司董事兼总经理皮宇被湖北省应...
美国天然气期货日内跌幅达3%,... 8月19日消息,美国天然气期货日内跌幅达3%,现报2.803美元/百万英热。(科股宝播报)
特朗普:乌克兰可能需要做出领土... 8月19日消息,据报道,美国总统特朗普当日在接受美国福克斯新闻网采访时表示,其将在未来几周内了解俄罗...
首相和防卫大臣拟“接力”访问东... 据日媒4月5日报道,日本首相高市早苗有意在4月底至5月上旬访问越南。报道称,日方希望通过所谓“政府安...
日本的安全,究竟靠什么? 近日,约2.4万名日本各界人士参加日本护宪和平团体在国会门前举行的大规模集会。抗议人士在现场高喊“自...
原创 特... 美国当地时间周一,美国总统特朗普就在新闻发布会上告诉记者,如果伊朗在周二晚间(美国东部时间)之前不达...