1、 vue中,父子組件通信最常用的方式就是props和 $emit,但是父組件傳遞給子組件的數據,能不能進行修改,修改后都有啥問題呢
2、先上代碼:
父組件代碼:
<!-- --> <template> <div class=''> <el-link type="danger">傳值為對象:</el-link> <div> 父組件中顯示fatherData的值:{{fatherData}} <l0705components :fatherData="fatherData"></l0705components> </div> <br><br><br> <el-link type="danger">傳值為字符串,使用v-model傳值:</el-link> <div> 父組件中顯示fatherData2的值:{{fatherData2}} <l0705components v-model="fatherData2"></l0705components> </div> <br><br> <el-link type="danger">傳值為字符串:</el-link> <div> 父組件中顯示fatherData3的值:{{fatherData3}} <l0705components :fatherData3="fatherData3"></l0705components> </div> </div> </template> <script> import l0705components from './views/l0705components' export default { name: "L0705L", components: { l0705components }, data() { // 這里存放數據 return { fatherData:{ name:"李四", age:"14" }, fatherData2:'父組件的數據2', fatherData3: '父組件的數據3' } } } </script>
子組件代碼:
<!-- --> <template> <div class=''> <div v-if="fatherData"> 子組件中顯示fatherData的值:{{fatherData}} <el-button type="danger" @click="changeFather"> 點擊修改父組件fartherData的值-姓名改為“王五” </el-button> </div> <div v-if="value!==''"> <input v-model="value"> </div> <div v-if="fatherData3!==''"> 子組件中顯示fatherData3的值:{{fatherData3}} <el-button type="danger" @click="changeFather3"> 點擊修改父組件fartherData3的值,改為“哈哈哈哈哈” </el-button> </div> </div> </template> <script> export default { props:{ fatherData:{ type:Object }, value: { type: String, default: '' }, fatherData3: { type: String, default: '' } }, name: "l0705components", data() { // 這里存放數據 return { } }, // 方法集合 methods: { changeFather(){ this.fatherData.name = '王五' }, changeFather3() { this.fatherData3 = '哈哈哈哈哈' } } } </script>
3、頁面展示:
4、測試結果說明:
(1)父組件傳遞一個對象,子組件接受,子組件中,直接修改接受到的對象里面的值,可以修改,父子組件的值都會隨之改變
(2)使用v-model傳值,修改input里面的值,會報錯
意思就是props傳遞的值不能進行修改
(3)點擊修改第三個值,在子組件中的值會修改,但是父組件中不能修改,報錯
5、總結:
父子組件傳值時,父組件傳遞的參數,數組和對象,子組件接受之后可以直接進行修改,並且會傳遞給父組件相應的值也會修改。
如果傳遞的值是字符串,直接修改會報錯。
不推薦子組件直接修改父組件中的參數,避免這個參數多個子組件引用,無法找到造成數據不正常的原因
6、官網說明:
https://cn.vuejs.org/v2/guide/components-props.html?
所有的 prop 都使得其父子 prop 之間形成了一個單向下行綁定:父級 prop 的更新會向下流動到子組件中,但是反過來則不行。這樣會防止從子組件意外改變父級組件的狀態,從而導致你的應用的數據流向難以理解。
額外的,每次父級組件發生更新時,子組件中所有的 prop 都將會刷新為最新的值。這意味着你不應該在一個子組件內部改變 prop。如果你這樣做了,Vue 會在瀏覽器的控制台中發出警告。