vue 在el-table内嵌套el-select点击选择下拉项不动态展示的解决办法

  参考:记一个vue 在el-table内嵌套el-select 无法点击选择的BUG解决办法 

el-select 怎么点击都无反应 但初始值是正常的 F12插件查看 父组件 el-table的属性 显示结果已经改变了 change事件也正常传递了改变后的值,仅仅是el-select自己显示有问题
查看el-select的value 没变化

 所以问题是所有人都变了 就他自己反而没变,猜测el-select的value变化并不由自己控制 而是主动传递事件改变v-model绑定的属性 再监听其属性改变 进而改变自己 现在监听失效了 

<el-table :data="supProcessList">
        <el-table-column label="流程应用类型" align="center" prop="name" min-width="180" show-overflow-tooltip>
        <template slot-scope="scope">
          <el-select v-model="scope.row.processType" placeholder="请选择流程应用类型" style="width: 100%" size="mini" @change="selProcessType">
            <el-option v-for="dict in processesOptions" :key="dict.dictValue" :label="dict.dictLabel" :value="dict.dictValue"></el-option>
          </el-select>
        </template>
      </el-table-column>
      </el-table>

最终 牵扯到了 el-select的 实现原理 wacth 对于 初始未在data内定义的属性可能监听失效
而我们el-select嵌套在 table内 其v-model绑定的属性 肯定是不可能一开始就声明的
我们只声明到了 supProcessList 这一级 而v-model绑定的是 supProcessList[index].events
猜测 改变supProcessList会使wacth生效

实现selProcessType方法

selProcessType() {
      this.supProcessList.push({ processType: [] })
      this.supProcessList.splice(this.supProcessList.length - 1, 1)
    },

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值