vue+element table表格实现动态列筛选的示例代码


Posted in Vue.js onJanuary 14, 2021

需求:在用列表展示数据时,出现了很多项信息需要展示导致表格横向特别长,展示就不够明晰,用户使用起来可能会觉得抓不住自己的重点。

设想实现:用户手动选择表格的列隐藏还是展示,并且记录用户选择的状态,在下次进入该时仍保留选择的状态。

效果图如下:

原:

vue+element table表格实现动态列筛选的示例代码

不需要的关掉默认的勾选:

vue+element table表格实现动态列筛选的示例代码

实现代码:
HTML部分就是用一个多选框组件展示列选项
v-if="colData[i].istrue"控制显示隐藏,把列选项传到checkbox里再绑定勾选事件。

<el-popover placement="right" title="列筛选" trigger="click" width="420">            
	<el-checkbox-group v-model="checkedColumns" size="mini">
		<el-checkbox v-for="item in checkBoxGroup" :key="item" :label="item" :value="item"></el-checkbox>
	</el-checkbox-group>
	<el-button slot="reference" type="primary" size="small" plain><i class="el-icon-arrow-down el-icon-menu" />列表项展示筛选</el-button>
</el-popover>
<el-table :data="attendanceList" @sort-change="sort" highlight-current-row :row-class-name="holidayRow" @selection-change="editAll" ref="multipleTable">
	<el-table-column type="selection" width="55" align="center"></el-table-column>
		<el-table-column label="员工基本信息">
		<el-table-column v-if="colData[0].istrue" align="center" prop="user_id" label="工号" width="80" fixed></el-table-column>
		<el-table-column v-if="colData[1].istrue" align="center" prop="name" label="姓名" width="80" fixed></el-table-column>
		<el-table-column v-if="colData[2].istrue" align="center" prop="age" label="年龄" width="60"></el-table-column>
		<el-table-column v-if="colData[3].istrue" align="center" prop="gender" label="性别" width="80"></el-table-column>
		<el-table-column v-if="colData[4].istrue" align="center" prop="department" label="部门名称" width="100"></el-table-column>
	</el-table-column>
	......

js 数据存放的data部分

//列表动态隐藏
	 colData: [
	   { title: "工号", istrue: true },
	   { title: "姓名", istrue: true },
	   { title: "年龄", istrue: true },
	   { title: "性别", istrue: true },
	   { title: "部门名称", istrue: true },	   
	 ],
	 checkBoxGroup: [],
	 checkedColumns: [],

js 方法实现部分

created() {      
	  // 列筛选
	  this.colData.forEach((item, index) => {
	    this.checkBoxGroup.push(item.title);
	    this.checkedColumns.push(item.title);
	  })
	  this.checkedColumns = this.checkedColumns
	  let UnData = localStorage.getItem(this.colTable)
	  UnData = JSON.parse(UnData)
	  if (UnData != null) {
	    this.checkedColumns = this.checkedColumns.filter((item) => {
	      return !UnData.includes(item)
	    })
	  }
	},
 // 监控列隐藏
 watch: {
   checkedColumns(val,value) {
     let arr = this.checkBoxGroup.filter(i => !val.includes(i)); // 未选中
     localStorage.setItem(this.colTable, JSON.stringify(arr))
     this.colData.filter(i => {
       if (arr.indexOf(i.title) != -1) {
         i.istrue = false;
       } else {
         i.istrue = true;
       }
     });
   }
 },

这样就可以实现了,并且在刷新页面等会记录勾选情况,本来想加一个全选的选择框,最后没实现,先这样用吧。但是肯定有更好的方法,以后优化了再更新~

到此这篇关于vue+element table表格实现动态列筛选的示例代码的文章就介绍到这了,更多相关element table表格动态列筛选内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue实现下载文件流完整前后端代码
Nov 17 Vue.js
vue祖孙组件之间的数据传递案例
Dec 07 Vue.js
vue实现登录、注册、退出、跳转等功能
Dec 23 Vue.js
vue+elementui通用弹窗的实现(新增+编辑)
Jan 07 Vue.js
vue实现一个获取按键展示快捷键效果的Input组件
Jan 13 Vue.js
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 Vue.js
vue实现同时设置多个倒计时
May 20 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
解决vue-router的beforeRouteUpdate不能触发
Apr 14 Vue.js
vue实现在data里引入相对路径
Jun 05 Vue.js
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
Aug 05 Vue.js
vue 递归组件的简单使用示例
Jan 14 #Vue.js
vue element和nuxt的使用技巧分享
Jan 14 #Vue.js
vue动态设置路由权限的主要思路
Jan 13 #Vue.js
vue组件是如何解析及渲染的?
Jan 13 #Vue.js
vue实现一个获取按键展示快捷键效果的Input组件
Jan 13 #Vue.js
vue使用vue-quill-editor富文本编辑器且将图片上传到服务器的功能
Jan 13 #Vue.js
基于VUE实现简单的学生信息管理系统
Jan 13 #Vue.js
You might like
php db类库进行数据库操作
2009/03/19 PHP
php tp验证表单与自动填充函数代码
2012/02/22 PHP
php查找任何页面上的所有链接的方法
2013/12/03 PHP
php判断页面是否是微信打开的示例(微信打开网页)
2014/04/25 PHP
async和DOM Script文件加载比较
2014/07/20 PHP
CI框架入门示例之数据库取数据完整实现方法
2014/11/05 PHP
php微信高级接口群发 多客服
2016/06/23 PHP
PHP封装的多文件上传类实例与用法详解
2017/02/07 PHP
Laravel 在views中加载公共页面的实现代码
2019/10/22 PHP
JS动态创建Table,Tr,Td并赋值的具体实现
2013/07/05 Javascript
jquery 页面滚动到指定DIV实现代码
2013/09/25 Javascript
JS图片自动轮换效果实现思路附截图
2014/04/30 Javascript
jQuery中prepend()方法使用详解
2015/08/11 Javascript
javascript 中Cookie读、写与删除操作
2017/03/29 Javascript
在vue2.0中引用element-ui组件库的方法
2018/06/21 Javascript
python使用htmllib分析网页内容的方法
2015/05/08 Python
详解Python中的静态方法与类成员方法
2017/02/28 Python
python机器学习实战之最近邻kNN分类器
2017/12/20 Python
Python使用pyh生成HTML文档的方法示例
2018/03/10 Python
Python FTP两个文件夹间的同步实例代码
2018/05/25 Python
django js实现部分页面刷新的示例代码
2018/05/28 Python
浅谈Scrapy网络爬虫框架的工作原理和数据采集
2019/02/07 Python
python3实现在二叉树中找出和为某一值的所有路径(推荐)
2019/12/26 Python
利用HTML5的新特点实现图片文件异步上传
2014/05/29 HTML / CSS
美国知名男士服饰品牌:Brooks Brothers(布克兄弟)
2016/08/25 全球购物
世界上最大的二手相机店:KEN
2017/05/17 全球购物
加拿大最大的箱包及旅游配件零售商:Bentley Leathers
2017/07/19 全球购物
开业庆典答谢词
2014/01/18 职场文书
1亿有多大教学反思
2014/05/01 职场文书
法定代表人授权委托书
2014/09/19 职场文书
2014群众路线学习笔记
2014/11/06 职场文书
四年级学生期末评语
2014/12/26 职场文书
校园新闻稿范文
2015/07/18 职场文书
关于分班的感言
2015/08/04 职场文书
导游词之南京汤山温泉
2019/11/26 职场文书
Windows server 2022创建创建林、域树、子域的步骤
2022/06/25 Servers