el-cascader回显开启多选,开启tag 导致的删除出现错误
具体配置
开启多选 开启tag 开启可删除 开启只显示末级
错误描述
当我根据后台数据回显后, 点击删除A 其实删除的确实B
解决方法
由于顺序错误的问题导致的, 回显顺序和数据源顺序不一样,
点击删除第一个会出现删除的是最后一个
el-cascader 显示的顺序是根据下拉列表的顺序展示的,并不是后台返回的顺序
分析:
el-cascader 的tag 是按照index排序的 ,没有绑定id,所以删除是根据name对应的index删除的, 所以 如果后端返回的数据顺序和你提交的顺序不一致就会出现 tag名称会回显出来 但是点击删除tag是删除的其他tag 通过remove-tag api 打印发现 当前id并不是当前name 的id 查看源码发现是 排序问题 但是怎么能让后端返回的顺序是你原始数据的顺序呢 ?
先拿到后台的数据然后赋值给cascader,然后根据getCheckedNodes获取 选中的值在赋值给绑定的数据
setTimeout(function() { //将id和name值对应
console.log(vm.editDataList.fsUnit.fsUnitId)
vm.editDataList.fsUnit.fsUnitId =
vm.$refs['cascader'].getCheckedNodes().map(function(node) {
return node.value
})
console.log(vm.editDataList.fsUnit.fsUnitId)
}, 1000)