继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

vue 组件通信的坑

熠熠生阳
关注TA
已关注
手记 67
粉丝 76
获赞 1245

             

   

vue 组件通信的坑

当传输的数据为引用类型时,一定要注意,有可能改了子组件的数据,父组件的数据也发生了改变

例子:

如给子组件传输数据:   dialogInfo

1

直接将行数据row(对象)赋值给: dialogInfos(dialogInfo)

1

在子组件中取值赋值: dialogInfo => ruleForm

11

但是问题来了!虽然经过了怎么几次赋值!但是 父组件row对象 与 子组件ruleFrom 仍然是一个对象, 他们在底层引用的是一个地址 => 一个对象

问题表现如下:

修改子组件数据:(ruleFrom.share_subtitle)

1

prop数据也变化了:(dialogInfo.form.share_subtitle)

1

父组件的行数据也变了:

1

以上问题的表明虽然 父 子 组件 的不同数据如果引用同一来源的引用数据,

虽然 用的是 不同 的 vue 观察者 , 然而 他们本质 却是 同一个 对象 ,

修改一个会改变其他的, 这会导致错误,正常情况子组件不能这样改变父组件的值!

解决方法:

最简单的方法是拷贝新的对象,赋值给子组件,做好隔离!

1

靳肖健      jxjweb.top


打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP