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 會在瀏覽器的控制台中發出警告。
