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+Element实现增删改查的示例源码
Nov 23 Vue.js
jenkins自动构建发布vue项目的方法步骤
Jan 04 Vue.js
vue+elementui通用弹窗的实现(新增+编辑)
Jan 07 Vue.js
通过vue.extend实现消息提示弹框的方法记录
Jan 07 Vue.js
vue element el-transfer增加拖拽功能
Jan 15 Vue.js
Vue项目打包部署到apache服务器的方法步骤
Feb 01 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Vue项目中如何封装axios(统一管理http请求)
May 02 Vue.js
vue+spring boot实现校验码功能
May 27 Vue.js
Vue+Element UI实现概要小弹窗的全过程
May 30 Vue.js
Vue如何清空对象
Mar 03 Vue.js
vue使用wavesurfer.js解决音频可视化播放问题
Apr 04 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网上商城购物车设计代码分享
2012/02/15 PHP
深入解析PHP的Laravel框架中的event事件操作
2016/03/21 PHP
php简单压缩css样式示例
2016/09/22 PHP
php实现简单的权限管理的示例代码
2017/08/25 PHP
javascript 二进制运算技巧解析
2012/11/27 Javascript
Javascript模块化编程(三)require.js的用法及功能介绍
2013/01/17 Javascript
jQuery模拟超链接点击效果代码
2013/04/21 Javascript
JS对HTML标签select的获取、添加、删除操作
2013/10/17 Javascript
使用JS或jQuery模拟鼠标点击a标签事件代码
2014/03/10 Javascript
移动手机APP手指滑动切换图片特效附源码下载
2015/11/30 Javascript
微信小程序 视图层(xx.xml)和逻辑层(xx.js)详细介绍
2016/10/13 Javascript
jquery对象与DOM对象转化
2017/02/08 Javascript
利用Javascript裁剪图片并存储的简单实现
2017/03/13 Javascript
ECMAscript 变量作用域总结概括
2017/08/18 Javascript
详解为Bootstrap Modal添加拖拽的方法
2018/01/05 Javascript
vue 多入口文件搭建 vue多页面搭建的实例讲解
2018/03/12 Javascript
JavaScript偏函数与柯里化实例详解
2019/03/27 Javascript
150行代码带你实现微信小程序中的数据侦听
2019/05/17 Javascript
Python使用matplotlib绘制三维图形示例
2018/08/25 Python
通过pykafka接收Kafka消息队列的方法
2018/12/27 Python
Python数据可视化之画图
2019/01/15 Python
Python利用itchat库向好友或者公众号发消息的实例
2019/02/21 Python
Python socket模块实现的udp通信功能示例
2019/04/10 Python
Django后端接收嵌套Json数据及解析详解
2019/07/17 Python
Python列表元素删除和remove()方法详解
2021/01/04 Python
耐克中国官方商城:Nike中国
2018/10/18 全球购物
俄罗斯化妆品和香水网上商店:Iledebeaute
2019/01/03 全球购物
好邻里事迹材料
2014/01/16 职场文书
生育关怀行动实施方案
2014/03/26 职场文书
2014年公务员转正工作总结
2014/11/07 职场文书
财务经理岗位职责
2015/01/31 职场文书
超市员工辞职信范文
2015/05/12 职场文书
2019银行员工个人工作自我鉴定
2019/06/27 职场文书
Angular CLI发布路径的配置项浅析
2021/03/29 Javascript
SqlServer 垂直分表(减少程序改动)
2021/04/16 SQL Server
MySQL REVOKE实现删除用户权限
2021/06/18 MySQL