当前位置:   article > 正文

elementui table 固定列_Vue动态控制表格列的显示和隐藏_vue table column 某一列是否出现

vue table column 某一列是否出现

1.效果如图

在这里插入图片描述
v-if=“lists[0].ispass” 来判断表格列的状态每一列是否显示或隐藏 勾选则展示、取消勾选隐藏、默认勾选

2.代码

<el-dropdown :hide-on-click="false">
            <i class="iconfont icon-shaixuan" ></i>
            <el-dropdown-menu slot="dropdown" >
              <el-scrollbar style="height: 60vh">//作用是数据过多把表单数据的整体高度固定、多出的区域可以下拉展示
                <el-checkbox-group v-model="check">
                  <el-dropdown-item v-for="(item,index) in checkList" :key="index"><el-checkbox :label="item" :key="item"></el-checkbox>
                  </el-dropdown-item>
                </el-checkbox-group>
              </el-scrollbar>
            </el-dropdown-menu>
</el-dropdown>
<el-table :data="institutionalTypeList" border align="center" v-loading="listLoading" style="width: 100%;" :header-cell-style="tableBg">
        <af-table-column type="index" :index="indexMethod" label="序号" width="90">
        </af-table-column>
        <af-table-column v-if="lists[0].ispass" prop="id" label="编码" >
        </af-table-column>
        <af-table-column v-if="lists[1].ispass" prop="name" label="名称" >
        </af-table-column>
        <af-table-column v-if="lists[2].ispass" prop="updatetime" label="更新时间" >
        </af-table-column>
</el-table>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

lists是所有表头标题,check是多选框默认全选,checkList也是所有表头标题、跟多选框绑定的

data() {
      return {
        check:['编码','名称','更新时间'],
        checkList:['编码','名称','更新时间'],
        lists:[
          {label:'编码',prop:'id',ispass:true},
          {label:'名称',prop:'name',ispass:true},
          {label:'更新时间',prop:'updatetime',ispass:true},
        ],
      }
    },
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

动态监听值选中的选项

watch:{
      check(newVal){
            if (newVal) {
              var arr = this.checkList.filter(i => newVal.indexOf(i) < 0) //未选中
              this.lists.map(i => {
                if (arr.indexOf(i.label) !== -1) {
                  i.ispass = false
                } else {
                  i.ispass = true
                }
              })
            }
      }
    },
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

相关资源:https://download.csdn.net/download/weixin_38647039/12953541?spm=1001.2101.3001.5697

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Guff_9hys/article/detail/740167
推荐阅读
相关标签