.sync是一个语法糖。是父组件监听子组件更新某个props的请求的缩写语法。
Vue中的 props 是单向向下绑定的,即:每次父组件更新时,子组件中的所有 props 都会刷新为最新的值。但是如果在子组件中修改 props ,Vue会向你发出一个警告。(无法通过修改子组件的props来更改父组件。)
因此我们可以在父组件使用子组件的标签上声明一个监听事件,在子组件想要修改时使用$emit触发事件并传入新的值,让父组件进行修改。
Vue帮我们做了一个修饰符,简化我们声明监听事件的写法,即.sync 修饰符。
示例:
<template>
<div class="details">
<!-- <myComponent :show.sync='valueChild' style="padding: 30px 20px 30px 5px;border:1px solid #ddd;margin-bottom: 10px;"></myComponent> -->
<myComponent :show="valueChild" @update:show="valueChild = $event" style="padding: 30px 20px 30px 5px;border:1px solid #ddd;margin-bottom: 10px;"></myComponent>
<button @click="changeValue">toggle</button>
</div>
</template>
<script>
import Vue from 'vue'
Vue.component('myComponent', {
template: `<div v-if="show">
<p>默认初始值是{{show}},所以是显示的</p>
<button @click.stop="closeDiv">关闭</button>
</div>`,
props:['show'],
methods: {
closeDiv() {
this.$emit('update:show', false); //触发 input 事件,并传入新值
}
}
})
export default{
data(){
return{
valueChild:true,
}
},
methods:{
changeValue(){
this.valueChild = !this.valueChild
}
}
}
</script>
示例来源:
深入理解vue 修饰符sync【 vue sync修饰符示例】www.jianshu.comv-model实现了双向绑定
以下是等同的
<input type="text" v-model="name">
//和
<input type="text" :value="name" @input="name=$event.target.value">
示例:
//APP.vue
<template>
<div class="">
<p>{{ name }}</p>
<son v-model="name"></son>
<!-- 等同于下面 -->
<!-- <son type="text" :value="name" @input="name=$event"/> -->
</div>
</template>
<script type="text/javascript">
import Son from "./components/son";
export default {
name: "",
data() {
return {
name: "sheben",
};
},
components: {
Son,
},
};
</script>
//.components/son.vue
<template>
<div class>
<input
type="text"
:value="value"
@input="$emit('input', $event.target.value)"
/>
</div>
</template>
<script type="text/javascript">
export default {
name: "",
props: {
value: {
type: String,
defalut() {
return "";
},
},
},
data() {
return {};
},
components: {},
};
</script>