当前位置:   article > 正文

element ui el-table展示列表,结合分页+过滤功能_vue table filters 如何控制分页

vue table filters 如何控制分页

vue+element-ui实现的列表展示,列表分页,列表筛选功能

1,分页器

el-table模块下面是分页器代码 <el-pagination></el-pagination>

  1. <el-table>
  2. </el-table>
  3. <!-- 分页器 -->
  4. <div class="block" style="margin-top:15px;margin-left:60%" v-if="tableData">
  5. <el-pagination
  6. @size-change="handleSizeChange"
  7. @current-change="handleCurrentChange"
  8. :current-page="currentPage"
  9. :page-sizes="[10,20,30,40,50,100]"
  10. :page-size=10
  11. layout="total, prev, pager, next,jumper"
  12. :total="tableData.length">
  13. </el-pagination>
  14. </div>

分页器  layout 属性表示组件布局

设置layout,表示分页器需要显示的内容,用逗号分隔,布局元素会依次显示。prev表示上一页,next为下一页,pager表示页码列表,除此以外还提供了jumpertotalsize和特殊的布局符号->->后的元素会靠右显示,jumper表示跳页元素,total表示显示页码总数,size用于设置每页显示的页码数量。

size-change 表示处理页码大小

current-change表示页面变动时触发的事件

page-sizes接受整型数组,数组元素为展示的选择每页显示个数的选项,[100, 200, 300, 400]表示四个选项,每页显示 100 个,200 个,300 个或者 400 个。

current-change 表示当前页,接受一个初始值表示首页在第几页。

page-size 表示每页item个数

total表示总体item数,例子代码中赋值为tableData的长度

2,过滤器

过滤功能

在<el-table-column>中设置filters,filter-method属性即可开启该列的筛选,filters 是一个数组,filter-method是一个方法,它用于决定某些数据是否显示,会传入三个参数:value, row 和 column

用例代码:

  1. <template>
  2. <el-table
  3. :data="tableData"
  4. style="width: 100%">
  5. <el-table-column
  6. prop="date"
  7. label="日期"
  8. sortable
  9. width="180"
  10. :filters="[{text: '2016-05-01', value: '2016-05-01'}, {text: '2016-05-02', value: '2016-05-02'}, {text: '2016-05-03', value: '2016-05-03'}, {text: '2016-05-04', value: '2016-05-04'}]"
  11. :filter-method="filterHandler"
  12. >
  13. </el-table-column>
  14. <el-table-column
  15. prop="name"
  16. label="姓名"
  17. width="180">
  18. </el-table-column>
  19. <el-table-column
  20. prop="address"
  21. label="地址"
  22. :formatter="formatter">
  23. </el-table-column>
  24. <el-table-column
  25. prop="tag"
  26. label="标签"
  27. width="100"
  28. :filters="[{ text: '家', value: '家' }, { text: '公司', value: '公司' }]"
  29. :filter-method="filterTag"
  30. filter-placement="bottom-end">
  31. <template slot-scope="scope">
  32. <el-tag
  33. :type="scope.row.tag === '家' ? 'primary' : 'success'"
  34. disable-transitions>{{scope.row.tag}}</el-tag>
  35. </template>
  36. </el-table-column>
  37. </el-table>
  38. </template>
  39. <script>
  40. export default {
  41. data() {
  42. return {
  43. tableData: [{
  44. date: '2016-05-02',
  45. name: '王小虎',
  46. address: '上海市普陀区金沙江路 1518 弄',
  47. tag: '家'
  48. }, {
  49. date: '2016-05-04',
  50. name: '王小虎',
  51. address: '上海市普陀区金沙江路 1517 弄',
  52. tag: '公司'
  53. }, {
  54. date: '2016-05-01',
  55. name: '王小虎',
  56. address: '上海市普陀区金沙江路 1519 弄',
  57. tag: '家'
  58. }, {
  59. date: '2016-05-03',
  60. name: '王小虎',
  61. address: '上海市普陀区金沙江路 1516 弄',
  62. tag: '公司'
  63. }]
  64. }
  65. },
  66. methods: {
  67. formatter(row, column) {
  68. return row.address;
  69. },
  70. filterTag(value, row) {
  71. return row.tag === value;
  72. },
  73. filterHandler(value, row, column) {
  74. const property = column['property'];
  75. return row[property] === value;
  76. }
  77. }
  78. }
  79. </script>

 filters是数组形式,元素是object类型,包括text属性和value属性。text属性时过滤下拉后让选择的选项,选择后使用相应的value值去匹配。匹配的方法是filter-method。

筛选后,每行数据 row都会进行filter-method的判断。

filterHandler分析

  1. filterHandler(value, row, column) {
  2. const property = column['property'];
  3. return row[property] === value;
  4. }

column['property']是当前列的prop属性值,比如如下代码,该column['property']是module。不设置该属性column['property']就是undefined,自然也无法选择出想要的数据。

  1. <el-table-column
  2. prop="module"
  3. :filters= "headFilters['module']"
  4. :filter-method="filterHandler"
  5. label="模块"
  6. min-width="3%"> </el-table-column>

一般的比较都是return row[property] === value;即 每行的module属性值与选中的filter item的value值相等选中。

3,结合使用遇到的问题

问题一:如何实现,点击新的页码或者下一页,table数据变化为相应的数据

el-table组件和el-pagination组件其实是两个分开的组件。

他们的联系是通过tableData来进行的。分页组件其实是产生了很多属性及其值,比如当前页currentPage,pageSize当前页的展示数据量pageSize。所以,el-table的“:data”属性就是计算后的分页段的数据: 

<el-table v-if="tableData" :key="fresh_table" :data="tableData.slice((currentPage-1)*pageSize,currentPage*pageSize)" 

问题二:加上过滤功能后,如何使得分页正常工作

以上<el-pagination>和过滤器的设置,是不是就能正常工作了呢?会存在一个问题,比如一个列表,分页每页10条数据,然后筛选。第一页10条数据,符合筛选规则5条,会呈现5条数据。第二页10条数据有3条符合规则,会在第三页展示3条数据。就是筛选只在每页筛选,分页器的总条数还是筛选前的总数据条数。如何改变呢?

el-table 有filter-change属性

filter-change当表格的筛选条件发生变化的时候会触发该事件,参数的值是一个对象,对象的 key 是 column 的 columnKey,对应的 value 为用户选择的筛选条件的数组。filters

可以利用该参数,进行一个table的数据再计算。就是 <el-table v-if="tableData" :key="fresh_table" :data="tableData.slice((currentPage-1)*pageSize,currentPage*pageSize)" 的tableData是过滤后的结果。

可以这样实现:

el-table定义filter-change:

            <el-table v-if="tableData" :key="fresh_table" :data="tableData.slice((currentPage-1)*pageSize,currentPage*pageSize)" @filter-change="handleFilterChange" width="100%">

handleFilterChange实现:

  1. handleFilterChange(value){
  2. if (!this.filterValue) {
  3. // 如果用户没有选择任何筛选条件,直接返回原始表格数据
  4. this.tableData=this.issues_detail;
  5. }
  6. // 使用 filter 方法过滤表格数据
  7. this.tableData=this.issues_detail.filter((row) => row[this.filterKey] === this.filterValue);
  8. this.fresh_table=!this.fresh_table
  9. },

其中变量 filterValue, filterKey,即fresh_table是定义在vue data对象中的变量:

  1. var history = new Vue({
  2. el: "#ss",
  3. data: {
  4. ....
  5. filterValue:null,
  6. filterKey:null,
  7. fresh_table:true,
  8. tableData:null,
  9. .....
  10. },

filterValue, filterKey记录过滤的key-vlaue值,在filterHandler中赋值。

  1. <el-table>
  2. ....
  3. <el-table-column
  4. prop="module"
  5. :filters= "headFilters['module']"
  6. :filter-method="filterHandler"
  7. label="模块"
  8. min-width="3%"> </el-table-column>
  9. .....
  10. </el-table>
  11. .....
  12. //位于vue的method中定义
  13. filterHandler(value, row, column) {
  14. const property = column['property'];
  15. this.filterValue=value
  16. this.filterKey=property
  17. return row[property] === value;
  18. },

以上fresh_table的使用,结合:key="fresh_table"  ,筛选完后改变其值使得列表更新,使用筛选后的tableData进行列表渲染

<el-table v-if="tableData" :key="fresh_table" :data="tableData.slice((currentPage-1)*pageSize,currentPage*pageSize)" @filter-change="handleFilterChange" width="100%">

以上基本就能实现分页+筛选列表功能,筛选后总体数量会变为符合筛选条件的数量,筛选结果分页。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/103083
推荐阅读
相关标签
  

闽ICP备14008679号