Vue prop传一个对象给子组件,怎么避免子组件修改数据污染父组件?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue prop传一个对象给子组件,怎么避免子组件修改数据污染父组件?相关的知识,希望对你有一定的参考价值。

参考技术A 实现点击修改表格信息,弹出对话框(子组件)修改本行数据,但是由于prop传的是一个对象,每次在对话框里修改的同时,父组件表格里的数据也会跟着改变。

看到了vue文档里的这句话:

引用数据类型中,前三者都是保存在变量对象中,而对象和数组保存在堆内存中,操作的只是他们的引用

用prop传递对象和数组时都会出现这种污染的情况,我的解决方法是在定义数据是把内部的数据单个重新定义一下,然后再赋值,适用于数据量较小的对象

23-父给子传值

参考技术A

一、父组件给子组件传值:
思路:在父组件绑定属性然后在子组件里通过props:["属性名"]接收值
父组件:

子组件:

所有的 prop 都使得其父子 prop 之间形成了一个 单向下行绑定 :父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。

额外的,每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你 应该在一个子组件内部改变 prop。如果你这样做了,Vue 会在浏览器的控制台中发出警告,但是我们可以通过对象是引用类型传递的是地址,就可以改变props单项数据流。

举个例子🌰

父组件:

子组件:

这样一来,当我点击子组件里边的文字时候,子组件和父组件的值都会改变,也不会报错。

二、哪几种情况下子组件需要修改props值?怎么做?

总结:父组件给子组件传值通过属性绑定,在子组件中通过props接受值,当更新父组件的值的时候,子组件也会自动更新。但是这个属于单项数据流,所以不应该在子组件修改,如果在子组件需要修改值,那可以在子组件通过在data中定义一个属性来保存props值。

如果直接修改父组件的值,浏览器会发出警告,当然我们也可以通过对象是引用类型的地址来修改,也不会发出警告。

以上是关于Vue prop传一个对象给子组件,怎么避免子组件修改数据污染父组件?的主要内容,如果未能解决你的问题,请参考以下文章

23-父给子传值

vue父组件向子组件传的值怎么放进子组件的data里面

父子组件传值

第十讲、Vue3.x父组件给子组件传值、Props、Props验证、单向数据流

vue父组件ref传值给子组件报错cannotreadproperty'getmsg'ofundefined

Vue.js2.0中子组件修改父组件传递过来的props,并不影响父组件的原始数据