Vue之2.x实现props双向绑定

vue2.0版本的props遵循单项数据流的准则,目的是防止双向绑定导致数据流向改动混乱,但业务中难免遇到需要对props进行双向绑定,封装子组件调用,实现组件的高复用性,例如element ui组件中的组件设计亦是如此。
通过阅读element ui的一些组件观察发现实现双向绑定功能的一个技术点是snyc修饰符,例如dialog组件:

<el-dialog
  title="提示"
  :visible.sync="dialogVisible" // 此处即是通过将vue data内注册的变量当作props传递给dialog组件,在dialog组件以sync在父子组件间实现双向绑定这个dialogVisible
  width="30%">
</el-dialog>

当在父组件内调用子组件时使用了.sync修饰符,则可以在子组件内改变props,子组件内修改props方法如下:

// dialog组件
this.$emit('update:visible', true/false); // update:后面声明的是要更新的props属性,this.$emit第二个参数是修改的值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值