父子组件嵌套时候 vue支持的是单向数据流,并非双向数据绑定的,
也就是常见的父组件经过props 传递数据进去,子组件经过emit派发事件,可是子组件是不能修改props的,由于这个数据是父组件的,vue
可是有的状况须要双向绑定,例如 popup弹层,外侧经过 某操做触发弹层显示传递props进去, popup组件内部会点击mask层 来取消显示,
<simpleCashier :cashier-visible.sync="cashierVisible"/>
props: { cashierVisible: { type: Boolean, default: false } }, data() { return { } }, computed: { show: { get() { return this.cashierVisible }, set(val) { this.$emit('update:cashierVisible', val) console.log(val) } } },
1 外部传递进来的 cashierVisible ,内部props接受的cashierVisible 后, 不可直接使用,由于当点击mask层组件会修改这个属性,就违背了vue的单向数据流原则,会报错this
[Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "cashierVisible"
2 按照上面说的咱们把外部传递进来的cashierVisible 属性换成计算属性 show,须要写set,get 以下双向绑定
computed: { show: { get() { return this.cashierVisible }, set(val) { this.$emit('update:cashierVisible', val) console.log(val) } } },
不然会报错code
[Vue warn]: Computed property "show" was assigned to but it has no setter.
在set里经过 this.$emit('update:cashierVisible', val) 把属性改变传递出去,完成~ 不能再set里直接给show赋值,不然会报第一条错误component