首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【vue】 el-table解决分页不能筛选全部数据的问题

【vue】 el-table解决分页不能筛选全部数据的问题

作者头像
fruge365
发布2025-12-15 10:32:53
发布2025-12-15 10:32:53
760
举报
前言

最近开发前端项目表格的时候,使用的是el-table,用到了对应的筛选功能,如下图所示

在这里插入图片描述
在这里插入图片描述

但发现实际只能筛选当前页,通过百度查找相关文章,发现原因是把筛选条件定义在列上,解决方法:所以我们把filter-change绑定在最外部即el-table上,参考文章:https://blog.csdn.net/zhiyikeji/article/details/109563064,下面代码

代码语言:javascript
复制
<el-table
  :data="bookRoomList"
  :ref="bookRoomList"
  @filter-change="handleFilterChange"
  class="bookTable"
  max-height="100%"
  stripe>

此时我们还需要在对应的筛选列上面定义一个column-key来作为筛选的监听状态(filters也可以改为模型中的数据)

代码语言:javascript
复制
<el-table-column
  :filter-multiple="false"
  :filters="[
    { text: '未审批', value: '0' },
    { text: '已审批', value: '1' },
    { text: '不予审批', value: '2' },
  ]"
  column-key="aStatus"
  filter-placement="bottom-end"
  label="审批状态"
  prop="status"
  width="180">
  <template slot-scope="scope">
    <el-tag v-if="scope.row.status=='0'">未审批</el-tag>
    <el-tag type="success" v-if="scope.row.status=='1'">已审批</el-tag>
    <el-tag type="danger" v-if="scope.row.status=='2'">不予审批</el-tag>
  </template>
</el-table-column>

对应的handleFilterChange事件如下:

代码语言:javascript
复制
handleFilterChange(filters) {
  console.log(filters)
  this.getList();//此处修改为自己定义的查询函数或者其他操作
}

需要注意的是,filters是一个数组,下面的项是事先在column-key里定义好的

在这里插入图片描述
在这里插入图片描述

我这里定义的是aStatus,控制台打印的filters如下:

在这里插入图片描述
在这里插入图片描述

其中aStatus就是filters对应的value值

在这里插入图片描述
在这里插入图片描述

当选择全部或重置时filters.aStatus就是空数组

在这里插入图片描述
在这里插入图片描述

一个表格的分页不能筛选全部的问题就迎刃而解。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-08-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档