需求实现:

代码逻辑:

按钮控件:

<el-popover placement="top-start">
<el-checkbox-group v-model="checkedColumns" @change="whenColumnBoxChange">
<div v-for="(col, idx) in optionColumns" :key="`optionColumns${idx}`">
<el-checkbox :label="col.property">{{ col.label }}</el-checkbox>
</div>
</el-checkbox-group>
<el-button style="float: right;" slot="reference" type="primary" size="mini">列筛选</el-button>
</el-popover>

  

表格组件要追加Ref标记:

 <el-table ref="elTable" v-loading="loading" size="small" stripe :height="tableHeight" :data="tableData">

需要设置的数据对象:

defaultShow: true,
checkedColumns: [],
optionColumns: []

所需方法:

// 当选择时重新渲染表格
whenColumnBoxChange() {
this.$refs['elTable'].doLayout()
},
// 判断该列是否展示
getColumnShowFlag(colIdent) {
return this.defaultShow || this.checkedColumns.includes(colIdent)
},
// 初始化筛选项,并保证默认正常展示 (created调用)
initialOptionColumnsData() {
this.$nextTick(() => {
const { columns } = this.$refs['elTable']
this.optionColumns = columns.filter(x => x.property).map(x => {
return { id: x.id, label: x.label, property: x.property, flag: true }
})
this.checkedColumns = this.optionColumns.map(x => x.property)
this.defaultShow = false
})
},

  

需要对一个个列进行判断方法设置:

<el-table-column v-if="getColumnShowFlag('apInAmount')" prop="apInAmount" min-width="120px" label="收入总额(元)" align="right" show-overflow-tooltip>
<template slot-scope="{ row }">
{{ transFormAmount(row.apInAmount) }}
</template>
</el-table-column>

  

更新补充

一、追加默认过滤的列:

初始化方法追加一个用来过滤的集合:

// 初始化筛选项,并保证默认正常展示
initialOptionColumnsData() {
this.$nextTick(() => {
const elTable = this.$refs['elTable']
this.optionColumns = elTable.columns.filter(x => x.property).map(x => {
return { id: x.id, label: x.label, property: x.property, flag: true }
})
this.checkedColumns = this.optionColumns.map(x => x.property).filter(x => !this.excludeColumns.includes(x))
this.defaultShow = false
elTable.doLayout()
})
},

在需要过滤的集合中设置字段property即可:

excludeColumns: [
'servCode',
'deName',
'inPmanagerName',
'inBegTime',
'inEndTime'
]

二、自定义列内容污染问题:

发现现有BUG,如果是扩展template自定义列内容时会污染下一列,解决办法就是对template也进行判断

<el-table-column v-if="getColumnShowFlag('apInAmount')" prop="apInAmount" min-width="120px" label="收入总额(元)" align="right" show-overflow-tooltip>
<template v-if="getColumnShowFlag('apInAmount')" slot-scope="{ row }">
{{ transFormAmount(row.apInAmount) }}
</template>
</el-table-column>

  

三、操作样式追补:

利用操作列固定头来设置,将按钮改为图标:

<el-table-column fixed="right" label="操作" width="180px" align="center">
<template slot="header">
<el-popover placement="top-start" trigger="hover">
<el-checkbox-group v-model="checkedColumns" @change="whenColumnBoxChange">
<div v-for="(col, idx) in optionColumns" :key="`optionColumns${idx}`">
<el-checkbox :label="col.property">{{ col.label }}</el-checkbox>
</div>
</el-checkbox-group>
<span slot="reference">
操作 <i class="el-icon-s-tools" style="margin-left: 5px;" />
</span>
</el-popover>
</template> <template slot-scope="scope">
<span v-permission="permits.update" class="link-color" @click="openEditDialog(scope.row)">
<i class="el-icon-edit-outline" /> 设置
</span> <span v-permission="permits.update" class="link-color" @click="openItemDialog(scope.row)">
<i class="el-icon-edit-outline" /> 计划
</span>
</template>
</el-table-column>

  

四、header插槽不更新复选框问题

el-table 后续使用嵌套组件加载时发现复选框不更新:

原因找到了:

https://blog.csdn.net/yy_demo/article/details/139067420

解决办法:

<template slot="header">
改为
<template #header>
检测数据更新刷新组件

  

五、发现存在nextTick报错:

初始化的列看不到值了

解决办法是对列增加key属性,标识唯一

https://www.jianshu.com/p/98f329c4a582

  

但是随后第二个功能的表格又不起作用了,排查了一下午问题才发现v-permission影响的

就是操作列中的操作标签使用了v-permission进行权限控制,但是在改用v-if后就不会报错了

为了优化使用方法,我追加了全局注册的方法

import Vue from 'vue'
import store from '@/store' /**
* 权限校验
*/
Vue.prototype.$permitValidate = val => {
return store.getters.permissions.includes(val)
}

  

【Vue】el-table 简易表格可筛选列的更多相关文章

  1. vue+element ui 的表格列使用组件

    前言:工作中用到 vue+element ui 的前端框架,有这个场景:很多表格的列有许多一样的,所以考虑将列封装为组件.转载请注明出处:https://www.cnblogs.com/yuxiaol ...

  2. layui table 数据表格 隐藏列

    现在国内的模板,也就layui一家独大了,其中的数据表格功能强大,但我不会用python或者django拼接json,输出发送给数据表格,那只好用笨办法,循环遍历吧. 数据表格中保留id列,是为了编辑 ...

  3. bootstrap table表格属性、列属性、事件、方法

    留存一份,原文地址http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/ 表格参数 表格的参数定义在 jQuery.fn.bootst ...

  4. jQuery遍历Table表格的行和列

    遍历Table表格的行和列,在开发中比较常用的功能,特别是前端开发人员,不多说,直接上代码,下面代码只是弹出第一列字段,请各位自己根据需求修改和扩展! <!DOCTYPE html PUBLIC ...

  5. vue+element创建动态的form表单.以及动态生成表格的行和列

    动态创建form表单,网上有插件 (form-create) 不过我不知道它怎么用,没有使用成功,如果你使用成功了,欢迎下方留言. 最后我使用了笨方法,针对各个表单写好通用的组件,然后根据type用v ...

  6. layui table 数据表格固定列的行高和table其他列的行高不一致

    1.问题描述:使用layui的table数据表格,固定某一列,这样表格中数据的宽度超出屏幕宽度时,固定列可以一直显示在屏幕中,不会随着底部滚动栏左右的拖动而变化位置.但是遇到一个问题,就是固定列的行高 ...

  7. LayUI之table数据表格获取行、行高亮等相关操作

    前言 目前LayUI数据表格既美观有不乏一些实用功能.基本上表格应有的操作已经具备,LayUI作者[贤心]肯定是煞费苦心去优化,此处致敬.但是实话实话,如果单纯那数据表格功能来说,EasUI的数据表格 ...

  8. vue绑值(表格)

    vue绑值(表格) <!DOCTYPE html> <html lang="zh-CN"> <head> <title>JSON取数 ...

  9. FineUI第十七天---- 表格之扩展列

    {          sb.AppendFormat(]); 1.通过表格的SelectedRowIndexArray获得选中行的索引号列表: 2.通过表格的DataKeys(二维数组)获取本行的数据 ...

  10. 做了一个jquery插件,使表格的标题列可左右拉伸

    示例下载 插件名称命名为:jquery.tableresize.js,代码如下: /* Writen by mlcactus, 2014-11-24 这是我封装的一个jquery插件,能够使table ...

随机推荐

  1. js 实现简易时钟效果

    大江东去,浪淘尽,千古风流人物.故垒西边,人道是,三国周郎赤壁.乱石穿空,惊涛拍岸,卷起千堆雪.江山如画,一时多少豪杰.遥想公瑾当年,小乔初嫁了,雄姿英发.羽扇纶巾,谈笑间,樯橹灰飞烟灭.故国神游,多 ...

  2. Windows10 LTSC版,比Win7还干净

    在Windows操作系统的发展历程中,每一个版本都承载着微软对用户需求的深度理解和技术创新.其中,Windows 7以其稳定.高效和简洁的特点,赢得了众多用户的喜爱. 然而,随着技术的不断进步和用户需 ...

  3. SELinux(一) 简介

    首发公号:Rand_cs 前段时间的工作遇到了一些关于 SELinux 的问题,初次接触不熟悉此概念,导致当时配置策略时束手束脚,焦头烂额,为此去系统的学习了下 SELinux 的东西.聊 SELin ...

  4. Scrapy框架(七)--中间件及Selenium应用

    中间件 下载中间件(Downloader Middlewares) 位于scrapy引擎和下载器之间的一层组件. 作用:批量拦截到整个工程中所有的请求和响应 - 拦截请求: - UA伪装:proces ...

  5. JVM性能分析与故障排查

    引言 JVM调优 程序在上线前的测试或运行中有时会出现一些大大小小的JVM问题,比如cpu load过高.请求延迟.tps降低等,甚至出现内存泄漏(每次垃圾收集使用的时间越来越长,垃圾收集频率越来越高 ...

  6. elasticsearch6.8 ik分词器需安装

    elasticsearch6.8  ik分词器需安装order_info_es/_analyze POST{ "analyzer": "ik_max_word" ...

  7. Unity中使用ProtocolBuffer

    Unity中使用ProtocolBuffer unityProtocolBufferUnity ProtocolBuggerC# ProtocolBuffer Unity中使用ProtocolBuff ...

  8. MongoDB文档存储

    非关系型数据库存储 NoSQL,全称 Not Only SQL,意为不仅仅是 SQL,泛指非关系型数据库.NoSQL 是基于键值对的,而且不需要经过 SQL 层的解析,数据之间没有耦合性,性能非常高. ...

  9. python实现推送消息到微信公众号

    使用到库: Requests 实现方式: 微信已开放了对应的接口,直接通过python的requests库,发起请求,实现推送消息到公众号 微信公众号准备: 1.没有注册微信公众号,可以使用微信提供的 ...

  10. 高通android QMI机制

    高通android QMI机制 原文(有删改):https://blog.csdn.net/u012439416/category_7004974 概论 Qualcomm MSM Interface, ...