不少时候,咱们会对 prop (父子组件传递数据的属性) 进行“双向绑定”vue
在vue 1.x 中的 .sync 修饰符所提供的功能。当一个子组件改变了一个带 .sync 的prop的值时,这个变化也会同步到父组件中所绑定的值。this
这很方便,但也会致使问题,由于它破坏了单向数据流。(数据自上而下流,事件自下而上走)debug
因为子组件改变 prop 的代码和普通的状体改动代码毫无区别,因此当你光看子组件的代码时,你彻底不知道它合适悄悄地改变了父组件的状态。双向绑定
这在 debug 复杂结构的应用时会带来很高的维护成本。因而咱们在 vue 2.0 中移除了 .sync 。事件
咱们须要作的只是 让子组件改变父组件状态的代码更容易被区分。同步
因而从 vue 2.3.0 开始,咱们从新引入了 .sync 修饰符,可是此次它只是做为一个编译时的语法糖存在。他会被自动扩展为一个 自动更新父组件属性的 v-on 监听器。it
<child :foo.sync=”msg”></child> 就会被扩展为: <child :foo=”bar” @update:foo=”val => bar = val”> (@是v-on的简写)编译
当子组件须要更新 foo 的值的时候,他须要显示的触发一个更新事件: this.$emit( “update:foo”, newValue );扩展