一、父组件给子组件传值:
思路:在父组件绑定属性然后在子组件里通过props:["属性名"]接收值
父组件:
<template>
<div>
<Child :message="message"></Child>
</div>
</template>
<script>
import child from '../common/Child.vue'
export default {
name:"parent",
components:{ //定义组件
Child:Child
},
data(){
return{
message:'组件'
}
}
}
</script>
子组件:
<template>
<div>
<h1>{{message}}</h1>
</div>
</template>
<script>
export default {
name:"Child",
props:["message"],
data(){
return{
}
},
}
</script>
单向数据流
所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。
额外的,每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你不应该在一个子组件内部改变 prop。如果你这样做了,Vue 会在浏览器的控制台中发出警告,但是我们可以通过对象是引用类型传递的是地址,就可以改变props单项数据流。
举个例子🌰
父组件:
<template>
<div>
<child :message="obj"></child>
{{obj.str}}
</div>
</template>
<script>
import Child from '../common/Child.vue'
export default {
name:"parent",
components:{
Child
},
data(){
return{
obj:{
str:"父组件"
}
}
}
}
</script>
子组件:
<template>
<div>
<h1 @click="run">{{message.str}}</h1>
</div>
</template>
<script>
export default {
name:"Child",
props:["message"],
data(){
return{
}
},
methods:{
run(){
this.message.str = "123"
}
}
}
</script>
这样一来,当我点击子组件里边的文字时候,子组件和父组件的值都会改变,也不会报错。
二、哪几种情况下子组件需要修改props值?怎么做?
-
这个 prop 用来传递一个初始值;这个子组件接下来希望将其作为一个本地的 prop 数据来使用。在这种情况下,最好定义一个本地的 data 属性并将这个 prop 用作其初始值:
props: ['initialCounter'], data() { return { counter: this.initialCounter } }
-
这个 prop 以一种原始的值传入且需要进行转换。在这种情况下,最好使用这个 prop 的值来定义一个计算属性:
props: ['size'], computed: { normalizedSize: function () { return this.size.trim().toLowerCase() } }
总结:父组件给子组件传值通过属性绑定,在子组件中通过props接受值,当更新父组件的值的时候,子组件也会自动更新。但是这个属于单项数据流,所以不应该在子组件修改,如果在子组件需要修改值,那可以在子组件通过在data中定义一个属性来保存props值。
如果直接修改父组件的值,浏览器会发出警告,当然我们也可以通过对象是引用类型的地址来修改,也不会发出警告。