vue 点击上数据上一条_vue从列表中选择一条数据,如何做到每次点击修改弹框都显示数据的本值,而不是上次编辑后没保存的值...

父组件将列表中选中的这个object给弹窗组件传进去;

弹窗组件内代码:

js:props: ['object', 'visible'],

computed: {

objectProp(){      return Object.assign({}, this.object)

}

},

html:el-input v-model=objectProp.name

只要我在外面不对选中的数据进行切换,每次我打开这个弹窗,显示的都是我上次修改的值;

如果我选中一条数据,第一次打开弹窗,显示的是数据本值,

假如数据本值是1,

我修改为2,

然后我关闭弹窗,

不切换选中的数据,再打开弹窗

此时显示的数据是2,而不是1,是上一次修改的值,我想让他显示为数据本值1,该怎么办

应该如何解决比较优雅呢,

目前我的解决方式是,将visible是否显示弹窗变量作为条件,每次这个值改变objectProp都会重新赋值一次,

但是这样的话,我打开弹窗和关闭弹窗都会给这个objectProp重新赋值,完全没有必要,代码很丑陋

objectProp(){    if(!this.visible){      return Object.assign({}, this.object)

}else{      return Object.assign({}, this.object)

}

},

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值