第一种,子组件通过监听父组件数据,子组件改变数据之后通知给父组件

原文链接:https://blog.csdn.net/m0_37728716/article/details/81776929

父组件 => props[parent-data] => 子组件 => watch[parent-data] => children-data = parent-data // 子组件监听父组件的改变

子组件 => $emit[children-data] => 父组件 => parant-data = children-data // 子组件通知父组件自身的改变

// 父组件
<template>
<div>
<Children :parentData="parentData" @getChildrenStatus="getChildrenStatus"></Children>
</div>
</template>
<script>
export default {
data(){
return {
parentData: 1
}
},
methods: {
getChildrenStatus: function(data){ // 实时更新子组件的变化
this.parentData = data
}
}
}
</script>
//子组件
<script>
export default {
data(){
return {
chiildrenData: 1
}
},
props: ['parentData'],
watch: {
parentData: function(){ // 监听父组件的变化
this.childrenData = this.parentData
}
},
mounted(){
this.$emit('getChildrenStatus', this.childrenData) // 将改变通知父组件(保证父子组件数据一致)
}
}
</script>

第二种 .sync 修饰符

在vue的组件通信props中,一般情况下,数据都是单向的,子组件不会更改父组件的值

那么vue提供.sync作为双向传递的关键字,实现了父组件的变动会传递给子组件,而子组件的foo改变时,通过事件机制,修改父组件的foo。完成了子组件newFoo和父组件foo的双向映射。

// 父组件
<Son :foo.sync="foo"></Son>
//子组件
props: ['foo'],
data: function () {
return {
newFoo: this.foo;
}
},
methods:{
add:function(){
this.newMsg=10;
this.$emit('update:foo',this.newFoo);
}
}

在一些情况下,可能会对一个props进行'双向绑定',事实上 , '.sync'修饰符提供了此功能

  • 当一个子组件改变了一个props 的值时,这个变化也会同步到父组件中所绑定的值
  • 也会导致问题,因为破坏了‘单项数据流’的假设,由于子组件改变props的代码和普通代码改懂毫无区别,当光看子组件代码时,完全不知何时改变了父组件的状态
  • 会被重新引入,扩展为一个自动更新父组件属性的v-on侦听器
  • v-model毕竟不是给组件与组件之间通信而设计的双向绑定,无论从语意上和代码写法上都没有,'.sync'直观和方便
  • 无论从v-model还是'.sync'修饰符来看,都离不开$emit 和 v-on 语法糖的封装,主要目的还是为了保证数据的正确单向流动与显示流动
<Son :foo.sync="sth"></Son>   //.sync修饰符
<Son :foo="sth" @update:foo="value=>sth=value"></Son>
  • :foo则是Son 子组件需要从父组件props接受的数据
  • 通过事件显示监听update:foo(foo则是props显示监听的数据),通过箭头函数执行回调,把函数传给sth,则就形成一种双向绑定循环链条
  • 当子组件需要更新foo的值时,需显示地触发更新事件
this.$emit('update:foo',newValue)

同时父组件@update:foo 也是依赖子组件的显示触发,这样可以轻松的捕捉到了数据的正常流动

  • 第一个参数则是 update 则是显示更新的事件,跟在后面的 :foo 则是需要改变对应的props值
  • 第二个参数传入的是希望父组件foo数据里将要变化的值,以及用于父组件接受update时更新数据

warn: 子组件改变父组件的数据时,update冒号后面的参数和父组件传递进来的值是同步的,想改变哪个,则冒号后面的值对应的就是哪个,两者相互对应,必填

Vue父子组件数据双向绑定,子组件可修改props的更多相关文章

  1. vue 利用v-model实现父子组件数据双向绑定

    v-model父组件写法: v-model子组件写法: 子组件export default中的model:{}里面两个值,prop代表着我要和props的那个变量相对应,event表示着事件,我触发事 ...

  2. 使用 v-model 实现 双向绑定.(子组件和父组件.)

    vue 自定义组件 v-model双向绑定. 父子组件同步通信   父子组件通信,都是单项的,很多时候需要双向通信.方法如下: 1.父组件使用:msg.sync="aa"  子组件 ...

  3. vue父组件数据改变,子组件数据并未发生改变(那是因为你没写监听)附带子组件的写法

    下面的代码有 父组件有三个按钮,年.月.日 点击之后父组件的数据发生改变,子组件却没改变,打印接受的数据,除了第一次其他都没打印,那是因为你没有写监听 <template> <div ...

  4. vue中v-model 数据双向绑定

    表单输入绑定 v-model 数据双向绑定,只能应用在input /textare /select <div id="app"> <input type=&quo ...

  5. vue 父子组件数据双向绑定

    父组件 <find-search v-model="searchshow"></find-search> 子组件 props: { value: { typ ...

  6. vue - 父组件数据变化控制子组件类名切换

    先说当时的思路和实现核心是父子组件传值和v-bind指令动态绑定class实现 1. 父组件引用.注册.调用子组件script中引用 import child from '../components/ ...

  7. Vue2.x中的父组件数据传递至子组件

    父组件结构 template <template> <div> <v-girl-group :girls="aGirls"></v-gir ...

  8. vue中的数据双向绑定

    学习的过程是漫长的,只有坚持不懈才能到达到自己的目标. 1.vue中数据的双向绑定采用的时候,数据劫持的模式.其实主要是用了Es5中的Object.defineProperty;来劫持每个属性的get ...

  9. [vue]实现父子组件数据双向绑定

    参考: http://www.cnblogs.com/xxcanghai/p/6124699.html <!DOCTYPE html> <html lang="en&quo ...

随机推荐

  1. Wireshark数据包分析入门

    Wireshark数据包分析(一)——使用入门   Wireshark简介: Wireshark是一款最流行和强大的开源数据包抓包与分析工具,没有之一.在SecTools安全社区里颇受欢迎,曾一度超越 ...

  2. 【Java Web开发学习】Spring消息-ActiveMQ发送消息

    ActiveMQ发送消息 转载:http://www.cnblogs.com/yangchongxing/p/9042401.html Java消息服务(Java Message Service, J ...

  3. HyperLedger Fabric 1.4 生产环境动态添加组织及节点

    网易云课堂视频在线教学,地址:https://study.163.com/course/introduction/1209401942.htm 1.1 操作概述      在“kafka生产环境部署” ...

  4. CURL命令学习二

    -a, --append 用于上传文件时,如果服务器上该文件不存在则创建,如果存在则追加到源文件. -K, --config <file> 指定从某个文件读取curl参数.如果指定-为文件 ...

  5. c++-构造函数练习和delete,new

    强化练习 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <iostr ...

  6. Springboot vue.js html 跨域 前后分离 shiro权限 集成代码生成器

    本代码为 Springboot vue.js  前后分离 + 跨域 版本 (权限控制到菜单和按钮) 后台框架:springboot2.1.2+ mybaits+maven+接口 前端页面:html + ...

  7. javascript中引用传递的问题如何解决

    我们有时候会向一个方法中传入一个参数,并且对这个参数做一些处理的操作: 但是因为是引用传递,处理过后会对原有的对象造成修改,无法进行反复使用. 如例子: 两次打印的结果一模一样.这样下一个方法在继续使 ...

  8. iOS核心动画高级技巧-5

    9. 图层时间 图层时间 时间和空间最大的区别在于,时间不能被复用 -- 弗斯特梅里克 在上面两章中,我们探讨了可以用CAAnimation和它的子类实现的多种图层动画.动画的发生是需要持续一段时间的 ...

  9. C#开发微信小程序(四)

    导航:C#开发微信小程序系列 关于小程序项目结构,框架介绍,组件说明等,请查看微信小程序官方文档,关于以下贴出来的代码部分我只是截取了一些片段,方便说明问题,如果需要查看完整源代码,可以在我的项目库中 ...

  10. python高阶函数—filter

    python内置了一个filter函数,用于过滤序列.和map函数类似,filter()函数也接受一个函数和一个序列.只不过filter函数中是把函数依次作用于序列中的每一个元素,如果是True则保留 ...