vue v-model双向绑定

父组件中

    <layer-import-hand-more v-model="visible"></layer-import-hand-more>
    visible=false

子组件中接受

model: {
      prop: 'visible',
      event: 'change',
},
props: {
      visible: Boolean,
},

这样进行绑定发现了Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders.说是不能改变父组件的整体属性的问题。

解决方案

父组件



    <layer-import-hand-more v-model="config"></layer-import-hand-more>
    config:{
        visible:false
    }
 

子组件 

model: {
      prop: 'visible',
      event: 'change',
},
props: {
      visible: Object,
},

这样可以并且不报错,猜测原因是父组件的值作为一个对象传到子组件,其中如果是Boolean类型  则是整个地址被换掉,因为基础类型值是直接指向值的地址,而对象而是先指向对象地址 ,在倒对象中寻找对应的值,这样后者即使里面的值被改了对象也不算被完全改变 还是那个地址。此乃个人理解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值