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如何实现验证码输入交互
Dec 07 Vue.js
vue的hash值原理也是table切换实例代码
Dec 14 Vue.js
vue实现图片裁剪后上传
Dec 16 Vue.js
Vue中computed和watch有哪些区别
Dec 19 Vue.js
基于Vue2实现移动端图片上传、压缩、拖拽排序、拖拽删除功能
Jan 05 Vue.js
如何在 Vue 表单中处理图片
Jan 26 Vue.js
vue+spring boot实现校验码功能
May 27 Vue.js
Vue实现跑马灯样式文字横向滚动
Nov 23 Vue.js
vue实现移动端div拖动效果
Mar 03 Vue.js
vue ref如何获取子组件属性值
Mar 31 Vue.js
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
vue的项目如何打包上线
Apr 13 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+javascript的日历控件
2009/11/19 PHP
php将字符串全部转换成大写或者小写的方法
2015/03/17 PHP
php检查是否是ajax请求的方法
2015/04/16 PHP
PHP 实现浏览记录并按日期分组
2017/05/11 PHP
Windows下php+mysql5.7配置教程
2017/05/16 PHP
如何在PHP中读写文件
2020/09/07 PHP
锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)
2010/03/24 Javascript
javascript 判断数组是否已包含了某个元素的函数
2010/05/30 Javascript
input按钮的事件处理大全
2010/12/10 Javascript
JavaScript 更严格的相等 [译]
2012/09/20 Javascript
以JSON形式将JS中Array对象数组传至后台的方法
2014/01/06 Javascript
ExtJS4给Combobox设置列表中的默认值示例
2014/05/02 Javascript
javascript下拉框选项单击事件的例子分享
2015/03/04 Javascript
jQuery如何获取动态添加的元素
2016/06/24 Javascript
JS for...in 遍历语句用法实例分析
2016/08/24 Javascript
NodeJS收发GET和POST请求的示例代码
2017/08/25 NodeJs
通过jquery.cookie.js实现记住用户名、密码登录功能
2018/06/20 jQuery
基于js实现抽红包并分配代码实例
2019/09/19 Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
2019/10/14 Javascript
浅谈Ant Design Pro 菜单自定义 icon
2020/11/17 Javascript
Python爬取三国演义的实现方法
2016/09/12 Python
python 实现求解字符串集的最长公共前缀方法
2018/07/20 Python
python数据预处理 :样本分布不均的解决(过采样和欠采样)
2020/02/29 Python
利用Python自动化操作AutoCAD的实现
2020/04/01 Python
使用python接受tgam的脑波数据实例
2020/04/09 Python
python math模块的基本使用教程
2021/01/16 Python
快速创建 HTML5 Canvas 电信网络拓扑图的示例代码
2018/03/21 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
加拿大最大的相机店:Henry’s
2017/05/17 全球购物
戴森比利时官方网站:Dyson BE
2020/10/03 全球购物
工作失误检讨书(3篇)
2014/10/11 职场文书
幼儿园欢迎词范文
2015/01/26 职场文书
餐饮店长岗位职责
2015/04/14 职场文书
2015年导购员工作总结
2015/04/25 职场文书
游戏《铁拳》动画化!2022年年内播出
2022/03/21 日漫
django项目、vue项目部署云服务器的详细过程
2022/07/23 Servers