记一个vue 在el-table内嵌套el-select 无法点击选择的BUG解决办法
代码片段如下正常情况下 我以为 压根不需要什么@change事件 按道理他自然就能修改表格下 行内的单元格数据然而想法太美好了,浪费了我2个小时期间找了N多办法没解决如change内调用$forceUpdate$set之类的BUG现象是这样的:el-select 怎么点击都无反应 但初始值是正常的F12插件查看 父组件 el-table的属性 显示结果已经改变了ch...
代码片段如下 正常情况下 我以为 压根不需要什么@change事件 按道理他自然就能修改表格下 行内的单元格数据
然而想法太美好了,浪费了我2个小时 期间找了N多办法没解决
如change内调用$forceUpdate $set之类的
BUG现象是这样的: el-select 怎么点击都无反应 但初始值是正常的 F12插件查看 父组件 el-table的属性 显示结果已经改变了 change事件也正常传递了改变后的值,仅仅是el-select自己显示有问题
查看el-select的value 没变化
所以问题是所有人都变了 就他自己反而没变,猜测el-select的value变化并不由自己控制 而是主动传递事件改变v-model绑定的属性 再监听其属性改变 进而改变自己 现在监听失效了
<el-table :data="result.gobalActions">
<el-table-column label="事件">
<template slot-scope="scope">
<el-select
:key="scope.$index"
v-model="scope.row.events"
multiple
placeholder="请选择"
@change="handleEvents"
>
<el-option
v-for="(item,index) in source.event.gobalActionTypes"
:key="index"
:value="item.value"
:label="item.label"
/>
</el-select>
</template>
</el-table-column>
<el-table-column
label="动作"
prop="name"
/>
</el-table>
最终 牵扯到了 el-select的 实现原理 wacth 对于 初始未在data内定义的属性可能监听失效
而我们el-select嵌套在 table内 其v-model绑定的属性 肯定是不可能一开始就声明的
我们只声明到了 result.gobalActions 这一级 而v-model绑定的是 result.gobalActions[index].events
猜测 改变result.gobalActions 会使wacth生效
实现handleEvents 方法
handleEvents(values) {
this.result.gobalActions.push({ events: [], name: '' })
this.result.gobalActions.splice(this.result.gobalActions.length - 1, 1)
// this.$forceUpdate()
}
结果 TMD 果然生效了!!!
所以解决办法就是 更新 data内有声明的那一级的属性让watch能顺利拿到新数据
感觉这解决办法非常的奇怪 但反正生效了,至于 // this.$forceUpdate() 为什么没效果 实在费解
更多推荐
所有评论(0)