vue 之 .sync 修饰符示例详解


Posted in Javascript onApril 21, 2018

在一些情况下,我们可能会需要对一个 prop (父子组件传递数据的属性) 进行“双向绑定”。

在vue 1.x 中的 .sync 修饰符所提供的功能。当一个子组件改变了一个带 .sync 的prop的值时,这个变化也会同步到父组件中所绑定的值。

这很方便,但也会导致问题,因为它破坏了单向数据流。(数据自上而下流,事件自下而上走)

由于子组件改变 prop 的代码和普通的状体改动代码毫无区别,所以当你光看子组件的代码时,你完全不知道它合适悄悄地改变了父组件的状态。

这在 debug 复杂结构的应用时会带来很高的维护成本。于是我们在 vue 2.0 中移除了 .sync 。

但是在实际应用中,我们发现 .sync 还是有其适用之处的,比如在开发可复用的组件库时。(懵逼○△○)

我们需要做的只是  让子组件改变父组件状态的代码更容易被区分。

于是从 vue 2.3.0 开始,我们重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。他会被自动扩展为一个  自动更新父组件属性的 v-on 监听器。

例如

<child :foo.sync=”msg”></child> 就会被扩展为: <child :foo=”bar” @update:foo=”val => bar = val”>  (@是v-on的简写)

 当子组件需要更新 foo 的值的时候,他需要显示的触发一个更新事件:   this.$emit( “update:foo”, newValue );

初始状态:

 vue 之 .sync 修饰符示例详解

 点击之后的状态:

 vue 之 .sync 修饰符示例详解

 vue 之 .sync 修饰符示例详解vue 之 .sync 修饰符示例详解

原理就是父组件向子组件传递了一个函数:function (newValue) { this.msg = newValue; }

vue 之 .sync 修饰符示例详解

当使用一个对象一次性设置多个属性的时候,这个 .sync 修饰符也可以和 v-bind 一起使用。

例如:  <child  v-bind.sync = “{ message: msg, uC: uc}”></child>     (不能写成  :.sync="{*********}",否则会报错的)

这个例子会为 message 和 uC 同时添加用于更新的 v-on 监听器。

 

vue 之 .sync 修饰符示例详解vue 之 .sync 修饰符示例详解vue 之 .sync 修饰符示例详解

总结

以上所述是小编给大家介绍的vue 之 .sync 修饰符示例详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
xmlhttp缓存清除的2种解决方法
Dec 13 Javascript
jQuery学习笔记之创建DOM元素
Jan 19 Javascript
如何实现chrome浏览器关闭页面时弹出“确定要离开此面吗?”
Mar 05 Javascript
Windows下用PyCharm和Visual Studio开始Python编程
Oct 26 Javascript
jquery实现网页的页面平滑滚动效果代码
Nov 02 Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
Oct 29 Javascript
禁用backspace网页回退功能的实现代码
Nov 15 Javascript
基于react后端渲染模板引擎noox发布使用
Jan 11 Javascript
VueCli3构建TS项目的方法步骤
Nov 07 Javascript
vue弹出框组件封装实例代码
Oct 31 Javascript
解决vue+router路由跳转不起作用的一项原因
Jul 19 Javascript
JavaScript实现淘宝商品图切换效果
Apr 29 Javascript
关于echarts在节点显示动态数据及添加提示文本所遇到的问题
Apr 20 #Javascript
vue中v-cloak解决刷新或者加载出现闪烁问题(显示变量)
Apr 20 #Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 #jQuery
vue多页面开发和打包正确处理方法
Apr 20 #Javascript
用ES6的class模仿Vue写一个双向绑定的示例代码
Apr 20 #Javascript
Vue写一个简单的倒计时按钮功能
Apr 20 #Javascript
使用Vue如何写一个双向数据绑定(面试常见)
Apr 20 #Javascript
You might like
php中将数组转成字符串并保存到数据库中的函数代码
2013/09/29 PHP
zend framework中使用memcache的方法
2016/03/04 PHP
AJAX PHP无刷新form表单提交的简单实现(推荐)
2016/09/09 PHP
PHP按符号截取字符串的指定部分的实现方法
2018/09/10 PHP
农历与西历对照
2006/09/06 Javascript
js 图片轮播(5张图片)
2008/12/30 Javascript
简单的js分页脚本
2009/05/21 Javascript
控制台报错object is not a function的解决方法
2014/08/24 Javascript
jquery手风琴特效插件
2015/02/04 Javascript
jquery实现实时改变网页字体大小、字体背景色和颜色的方法
2015/08/05 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
2015/08/25 Javascript
使用pcs api往免费的百度网盘上传下载文件的方法
2016/03/17 Javascript
Jquery ui datepicker设置日期范围,如只能隔3天【实现代码】
2016/05/04 Javascript
Web纯前端“旭日图”实现元素周期表
2017/03/10 Javascript
Vue学习笔记进阶篇之vue-cli安装及介绍
2017/07/18 Javascript
Angular通过指令动态添加组件问题
2018/07/09 Javascript
vue 2.8.2版本配置刚进入时候的默认页面方法
2018/09/21 Javascript
浅谈layui数据表格判断问题(加入表单元素),设置单元格样式
2019/10/26 Javascript
java遇到微信小程序 &quot;支付验证签名失败&quot; 问题解决
2019/12/22 Javascript
vue页面更新patch的实现示例
2020/03/25 Javascript
[02:10]DOTA2亚洲邀请赛 EG战队出场宣传片
2015/02/07 DOTA
Python实现把数字转换成中文
2015/06/29 Python
python机器学习库scikit-learn:SVR的基本应用
2019/06/26 Python
浅析python中while循环和for循环
2019/11/19 Python
Flask之pipenv虚拟环境的实现
2019/11/26 Python
Python中bisect的使用方法
2019/12/31 Python
python飞机大战游戏实例讲解
2020/12/04 Python
英国最大的百货公司:Harrods
2016/08/18 全球购物
高中毕业自我鉴定
2013/12/16 职场文书
计算机专业职业生涯规划范文
2014/01/19 职场文书
学子宴答谢词
2014/01/25 职场文书
致垒球运动员加油稿
2014/02/16 职场文书
交通事故案件代理词
2015/05/23 职场文书
高中班主任寄语
2019/06/21 职场文书
MySQL系列之七 MySQL存储引擎
2021/07/02 MySQL
Go语言的协程上下文的几个方法和用法
2022/04/11 Golang