vuejs中的watch/对象与数组失效
2023-05-21 本文已影响0人
勤劳一沙鸥
问题:deep watch 不生效。
代码:
vue3中传统的watch方式观察 patient对象的变化
Form代码省略
...
watch: {
patient: {
handler: function (nv, ov) {
doSomeThing()
},
deep: true,
},
},
async created() { // 服务器 端还原表单
this.fetchPatientDetail(patientId);
},
setup() {
const patient = ref({});
return {
patient
};
}
排查:
发现vuex中,patient对象变成的空数组。
data:image/s3,"s3://crabby-images/9fe46/9fe46182ac34417913c25e3352942903737d60d6" alt=""
神奇的是可以提交,但watch无效。
data:image/s3,"s3://crabby-images/f37ee/f37ee934ea29bbd33dfb760eed4d4cc84462c59a" alt=""
修改:
将 vuex 中的数组修改为对象,貌似可以正常工作了
data:image/s3,"s3://crabby-images/90793/907935935f93395d5752ae56c62be0a2182388dd" alt=""
patient对象在表单还原时,由于php的原因,空对象就直接输入[]
,导致js的这个现象。后端同学返回加了一个对象转换,可以解决。
更深层次的原因后边挖掘,这里记录一下问题吧。 各种尝试修改,花了1个多小时...