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 相关文章推荐
在IE下:float属性会影响offsetTop的取值
Dec 22 Javascript
jQuery实现隔行背景色变色
Nov 24 Javascript
jQuery基于json与cookie实现购物车的方法
Apr 15 Javascript
AngularJS通过$sce输出html的方法
Sep 22 Javascript
js记录点击某个按钮的次数-刷新次数为初始状态的实例
Feb 15 Javascript
Javascript创建类和对象详解
May 31 Javascript
使用vue如何构建一个自动建站项目
Feb 05 Javascript
在angular 6中使用 less 的实例代码
May 13 Javascript
vue项目引入Iconfont图标库的教程图解
Oct 24 Javascript
Vue.js 使用v-cloak后仍显示变量的解决方法
Nov 19 Javascript
Vue使用watch监听一个对象中的属性的实现方法
May 10 Javascript
JS桶排序的简单理解与实现方法示例
Nov 25 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 set_time_limit(0)长连接的实现分析
2010/03/02 PHP
PHP 模拟$_PUT实现代码
2010/03/15 PHP
typecho插件编写教程(六):调用接口
2015/05/28 PHP
PHP经典面试题之设计模式(经常遇到)
2015/10/15 PHP
Laravel中正确地返回HTTP状态码方法示例
2019/09/10 PHP
PHP实现文件上传与下载
2020/08/28 PHP
JavaScript 利用Cookie记录用户登录信息
2009/12/08 Javascript
jQuery前台数据获取实现代码
2011/03/16 Javascript
Js判断参数(String,Array,Object)是否为undefined或者值为空
2013/11/04 Javascript
js判断数据类型如判断是否为数组是否为字符串等等
2014/01/15 Javascript
js中函数调用的两种常用方法使用介绍
2014/07/17 Javascript
利用JQuery阻止事件冒泡
2016/12/01 Javascript
详解angularJs指令的3种绑定策略
2017/04/13 Javascript
详解angularjs利用ui-route异步加载组件
2017/05/21 Javascript
微信小程序之前台循环数据绑定
2017/08/18 Javascript
Vue列表如何实现滚动到指定位置样式改变效果
2020/05/09 Javascript
Python实现的数据结构与算法之基本搜索详解
2015/04/22 Python
Python3.x版本中新的字符串格式化方法
2015/04/24 Python
python计算文本文件行数的方法
2015/07/06 Python
python检查指定文件是否存在的方法
2015/07/06 Python
python监控进程脚本
2018/04/12 Python
利用Anaconda简单安装scrapy框架的方法
2018/06/13 Python
mvc框架打造笔记之wsgi协议的优缺点以及接口实现
2018/08/01 Python
pandas 数据索引与选取的实现方法
2019/06/21 Python
python实现抠图给证件照换背景源码
2019/08/20 Python
Tensorflow进行多维矩阵的拆分与拼接实例
2020/02/07 Python
遮罩层 + Iframe实现界面自动显示的示例代码
2020/04/26 HTML / CSS
幼儿园家长寄语
2014/04/02 职场文书
超市创业计划书
2014/04/24 职场文书
学术诚信承诺书
2014/05/26 职场文书
2015年行风建设工作总结
2015/05/15 职场文书
2015年党小组工作总结
2015/05/26 职场文书
开国大典观后感
2015/06/04 职场文书
幼儿园小班教学反思
2016/03/03 职场文书
css3 实现文字闪烁效果的三种方式示例代码
2021/04/25 HTML / CSS
JS不要再到处使用绝对等于运算符了
2021/04/30 Javascript