在有些情況下,我們可能需要對一個 prop 進行“雙向綁定”。不幸的是,真正的雙向綁定會帶來維護上的問題,因為子組件可以修改父組件,且在父組件和子組件都沒有明顯的改動來源。 所以就推薦以update:myPropName 的模式觸發事件取而代之。舉個例子,在一個包含 title prop 的假設的組 ...
在有些情况下,我们可能需要对一个 prop 进行“双向绑定”。不幸的是,真正的双向绑定会带来维护上的问题,因为子组件可以修改父组件,且在父组件和子组件都没有明显的改动来源。
所以就推荐以update:myPropName
的模式触发事件取而代之。举个例子,在一个包含 title
prop 的假设的组件中,我们可以用以下方法表达对其赋新值的意图:
this.$emit('update:title', newTitle)
然后父组件可以监听那个事件并根据需要更新一个本地的数据属性。例如:
<text-document v-bind:title="doc.title" v-on:update:title="doc.title = $event" ></text-document>
为了方便起见,我们为这种模式提供一个缩写,即 .sync
修饰符:
<text-document v-bind:title.sync="doc.title"></text-document>
例子:
父组件:parent.vue
<template> <div > //input实时改变num的值, 并且会实时改变div里的内容 <input type="text" v-model="num"> <child:childnum.sync="num" ></child> </div> </template> <script> import child from './child.vue' //引入child子组件 export default { data() { return { num: '' } }, components: { child } } </script>
子组件:child.vue
<template> <div> <div> <input type="text" v-model="str"> </div> //childnum是父元素传过来的 <h2>{{ childnum }}</h2> </div> </template> <script> export default { data() { return { str: '', } }, props:["childnum”] watch: { str: function(newValue, oldValue) { //每当str的值改变则发送事件update:childnum , 并且把值传过去 this.$emit('update:childnum', newValue) } } } </script>