vue 动态列筛选
标签搜索
侧边栏壁纸
博主昵称
2c

  • 累计撰写 19 篇文章
  • 累计收到 12 条评论

vue 动态列筛选

2c
2c
2022-05-23 / 0 评论 / 11 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2022年05月23日,已超过736天没有更新,若内容或图片失效,请留言反馈。

Test

实现代码:
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>
 </el-table>

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;
       }
     });
   }
 },
0

评论 (0)

取消