v-model
v-model就是vue的双向绑定的指令,能将页面上控件输入的值同步更新到相关绑定的data属性,也会在更新data绑定属性时候,更新页面上输入控件的值。
<input v-model='val'></input>
等价于
<input :value="val" @input="val=$event.target.value"></input>
简单理解为:在input框里面通过v-bind动态绑定一个value,然后在input框里面通过@input方法去动态获取input输入的值,然后重新给变量赋值就可以了 值得一提的是vue中的.sync和v-model的功能是类似的
.sync
.sync修饰符可以实现子组件与父组件的双向绑定,并且可以实现子组件同步修改父组件的值。
一般情况下,想要实现父子组件间值的传递,通常使用的是 props 和自定义事件 emit 将值传给父组件,父组件通过事件j监听获取子组件传过来的值。 如果想要简化这里的代码,可以使用.sync修饰符,实际上就是一个语法糖。
<com1 :a="num" :b="num2"></com1>
// 加上sync之后父传子:
<com1 :a.sync="num" .b.sync="num2"></com1>
// 它等价于
<com1
:a="num" @update:a="val=>num=val"
:b="num2" @update:b="val=>num2=val"></com1>
// 相当于多了一个事件监听,事件名是update:a,回调函数中,会把接收到的值赋值给属性绑定的数据项中。
总结
.sync与v-model区别是
- 相同点:都是语法糖,都可以实现父子组件中的数据的双向通信。
- 区别点:
-
- 格式不同。
v-model="num", :num.sync="num"
- 格式不同。
-
- v-model: @input + value
-
- :num.sync: @update:num
-
- v-model只能用一次;.sync可以有多个。