关于element-ui中,页面上有多个el-table并通过v-if、v-else等控制是否显示时,type=selection勾选框失效或不显示的问题

刚开始是勾选框那一列直接空了什么都不显示,搜索了一下说是给el-table标签增加id,加了之后是显示了,但是点击任何选框都会直接取消全部选中效果,翻了半天源码也没发现到底是哪里事件冲突了还是怎么回事,烦了,干脆自己写勾选框了。首先把type=selection的列修改一下:

复制代码
 <!-- 原来: -->
<el-table-column
      type="selection"
      width="55"
      align="center"
/>
 <!-- 现在: -->
<el-table-column
    width="55"
    align="center"
>
    <template
        slot-scope="{row}"
        slot="header"
    >
        <el-checkbox 
            :indeterminate="isIndeterminate"
            v-model="checkAll"
            @change="handleCheckAllChange">
        </el-checkbox>
    </template>
    <template slot-scope="scope">
         <el-checkbox v-model="scope.row.checked" @change="handleCheckedChange"/>
    </template>
</el-table-column>

获取数据的时候记得加上checked用于绑定是否选中:

复制代码
var ids = '' //已被选中保存过的id们 另外一个接口获取 我就不写了
//列表数据 接口获取过了
this.listData.forEach((element, index) => {
    //在已保存列表里 选中
    if (ids.indexOf(element.id) != -1) {
        this.$set(this.listData[index], 'checked', true)
    } else {
        this.$set(this.listData[index], 'checked', false)
    }
})

勾选事件:

复制代码
//单个checkbox选中/不选事件
    handleCheckedChange (value) {
      let checkedCount = value.length;
      //判断是否变成了全选/全不选 置状态
      this.checkAll = checkedCount === this.listData.length;
      this.isIndeterminate = checkedCount > 0 && checkedCount < this.listData.length;
    },
    //全选/全不选切换
    handleCheckAllChange (val) {
      //改变每一条的选中状态
      this.listData.forEach((element, index) => {
        this.$set(this.listData[index], 'checked', val)
      })
    //全选框的状态 单纯显示
      this.isIndeterminate = false;
    },
相关推荐
Sheldon一蓑烟雨任平生20 小时前
Vue3 插件(可选独立模块复用)
vue.js·vue3·插件·vue3 插件·可选独立模块·插件使用方式·插件中的依赖注入
鱼与宇1 天前
苍穹外卖-VUE
前端·javascript·vue.js
用户47949283569151 天前
Safari 中文输入法的诡异 Bug:为什么输入 @ 会变成 @@? ## 开头 做 @ 提及功能的时候,测试同学用 Safari 测出了个奇怪的问题
前端·javascript·浏览器
裴嘉靖1 天前
Vue 生成 PDF 完整教程
前端·vue.js·pdf
毕设小屋vx ylw2824261 天前
Java开发、Java Web应用、前端技术及Vue项目
java·前端·vue.js
冴羽1 天前
今日苹果 App Store 前端源码泄露,赶紧 fork 一份看看
前端·javascript·typescript
蒜香拿铁1 天前
Angular【router路由】
前端·javascript·angular.js
时间的情敌1 天前
Vite 大型项目优化方案
vue.js
西洼工作室1 天前
高效管理搜索历史:Vue持久化实践
前端·javascript·vue.js
樱花开了几轉1 天前
element ui下拉框踩坑
开发语言·javascript·ui