vue中的.sync修饰符的使用


在说vue 修饰符sync前,我们先看下官方文档: vue .sync 修饰符,里面说vue .sync 修饰符以前存在于vue1.0版本里,但是在在 2.0 中移除了 .sync 。但是在 2.0 发布之后的实际应用中,我们发现 .sync 还是有其适用之处,比如在开发可复用的组件库时。我们需要做的只是让子组件改变父组件状态的代码更容易被区分。从 2.3.0 起我们重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 监听器。
示例代码如下:
<comp :foo.sync="bar"></comp>

会被展开为:

<comp :foo="bar" @update:foo="val => bar = val"></comp>

当子组件需要更新 foo 的值时,它需要显式地触发一个更新事件:

this.$emit('update:foo', newValue)

下边我么通过一个实例(弹窗的关闭事件)来说明这个代码到底是怎么运用的。

 1 <template>
 2     <div class="details">
 3         <myComponent :show.sync='valueChild' style="padding: 30px 20px 30px 5px;border:1px solid #ddd;margin-bottom: 10px;"></myComponent>
 4         <button @click="changeValue">toggle</button>
 5     </div>
 6 </template>
 7 <script>
 8 import Vue from 'vue'
 9 Vue.component('myComponent', {
10       template: `<div v-if="show">
11                     <p>默认初始值是{{show}},所以是显示的</p>
12                     <button @click.stop="closeDiv">关闭</button>
13                  </div>`,
14       props:['show'],
15       methods: {
16         closeDiv() {
17           this.$emit('update:show', false); //触发 input 事件,并传入新值
18         }
19       }
20 })
21 export default{
22     data(){
23         return{
24             valueChild:true,
25         }
26     },
27     methods:{
28         changeValue(){
29             this.valueChild = !this.valueChild
30         }
31     }
32 }
33 </script>
View Code

动态效果图如下:

 

vue 修饰符sync的功能是:当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定。如果我们不用.sync,我们想做上面的那个弹窗功能,我们也可以props传初始值,然后事件监听,实现起来也不算复杂。这里用sync实现,只是给大家提供一个思路,让其明白他的实现原理,可能有其它复杂的功能适用sync。

这只是一个简单的例子,看完这个不知你是不觉得有个指令跟这个很相似,v-model?对,就是v-model在组件上使用的时候。
具体的可以查看:vue 自定义组件使用v-model,可以实现同样的功能。也是以这个弹窗事件做演示的

转发自: https://www.jianshu.com/p/6b062af8cf01


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM