经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
Vue实现动态控制表格列的显示和隐藏
来源:jb51  时间:2022/4/11 18:16:02  对本文有异议

本文实例为大家分享了Vue实现动态控制表格列的显示和隐藏的具体代码,供大家参考,具体内容如下

效果如图:

表头标题是重复的、为了能看到滚动效果

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

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

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

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

动态监听值选中的选项

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号