Vue的组件通讯又称组件传值

一、父子组件传值:

  父组件:

    <子组件名   :动态变量名 (随便起)='你想要传递的数据' ></子组件名>

   子组件:

    利用 prop去接收父组件传过来的值

    props:[ '父组件传递过来的动态变量(可以接收多个)' ]

    ** 注意点

    props属性的优先级要高于data属性(data中的参数值不要和props中的值的名字重复,否则会覆盖)

    父组件传值是单项数据且不能跨代传值

  

二、子父组件传值

    子组件:

    <button  @click='事件名称' ></button>

    methods:{

      事件名称(){

        //利用事件触发器以及自定义事件名称发送数据

        this.$emit('自定义事件名称',数据)

      }

    }

    父组件:

    <子组件 @定义事件名称='事件名称(自己新定义的事件名,用来接收数据,触发事件)'>  </子组件>

    methods:{

      事件名称(e){

        // e 是数据源,就是子组件传递过来的数据

      } 

    }

三、兄弟组件传值(非父子传值)

    实现的方法有三种:

    1 单一事件(缺点,必须在同一个页面,主要用于兄弟组件)

    //在main.js中给Vue实例添加一个方法,接下来所有的组件都可以使用这个方法

        Vue.prototype.eventBus(定义的变量)   = new Vue()

    //自定义的兄弟页面VB.vue页面

      <div><button @click='toA'>传送数据给A</button></div>

      methods:{

        toA( ){

          //发送数据给A

          //调用触发事件

          //$emit('事件名称', 数据)

          this.eventBus.$emit('sendA', this.msg)

        }

      }

    //自定义的兄弟页面VA.vue

      mounted(){

        //调用实时监听事件的变化

        this.eventBus.$on('sendA', (e)=>{

          console.log(e,'接收到b的数据');

          this.dataB = e ;

        })

      }

     2 本地存储方法:

        本地存储:localStorage

        会话存储:sessionStorage

      <button @click = ' toLocal '>本地存储</button>

      methods:{

        toLocal(){

          //localStorage.setItem('本地存储的key','需要存储的数据')

          localStorage.setItem('info',this.info)

        }

      }

      接收本地存储的参数

      mounted:{

        this.info = localStorage.getItem('info(本地存储中的key值)')

      }

      会话存储:sessionStorage(方法一样):

      

      <button @click = ' toLocal '>本地存储</button>

      methods:{

        toLocal(){

          //localStorage.setItem('本地存储的key','需要存储的数据')

          localStorage.setItem('info',this.info)

        }

      }

      接收本地存储的参数

      mounted:{

        this.info = localStorage.getItem('info(本地存储中的key值)')

      }

      3 Vuex状态管理

    

vue的组件通讯的更多相关文章

  1. seventBus(封装) 一个巧妙的解决vue同级组件通讯的思路

    如果在你项目中需要多处用到同级组件通讯,而又不想去写繁琐的vuex,可以参考这个小思路.本人在写项目中琢磨出来的,感觉挺好用,分享一下. 1.在utils文件夹下添加BusEvent.js 注释已经很 ...

  2. vue的组件通讯 父传子 -- 子传父-- 兄弟组件的传值 vue的组件传值

    首先文字简单撸一下 父子传子   -------首先在父组件上绑定一个属性,在子组件里用props接收,可以是数组或者是对象 子传父   ------在父组件升上自定义一个方法,在子组件里通过this ...

  3. vue同胞组件通讯解决方案(以下为一种另外可用vuex解决)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. 深入理解Vue父子组件通讯的属性和事件

    在html中使用元素,会有一些属性,如class,id,还可以绑定事件,自定义组件也是可以的.当在一个组件中,使用了其他自定义组件时,就会利用子组件的属性和事件来和父组件进行数据交流. 父子组件之间的 ...

  5. Vue父子组件通讯

    我们知道,父组件不能修改子组件的数据[这种说法是不严谨的],严谨的说法是:子组件内部不能修改从父组件传递过来的值.原因是vue遵循的是数据单向流原则,父组件传递数据给子组件只能单向绑定,通过Props ...

  6. vue组件通讯之provide / inject

    什么是 provide / inject [传送门] vue的组件通讯方式我们熟知的有 props $emit bus vuex ,另外就是 provide/inject provide/inject ...

  7. 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据

    前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...

  8. Vue组件通讯

    Vue最常用的组件通讯有三种:父->子组件通讯.子->父组件通讯,兄弟组件通讯.(template用的pug模板语法) 1.父->子组件通讯 父->子组件通讯,是通过props ...

  9. Vue组件通讯黑科技

    Vue组件通讯 组件可谓是 Vue框架的最有特色之一, 可以将一大块拆分为小零件最后组装起来.这样的好处易于维护.扩展和复用等. 提到 Vue的组件, 相必大家对Vue组件之间的数据流并不陌生.最常规 ...

随机推荐

  1. MySQL----SQL操作

    1.什么是SQL? Structured Query Language:结构化查询语言 其实就是定义了操作所有关系型数据库的规则.每一种数据库操作的方式存在不一样的地方,称为“方言”. 2.SQL通用 ...

  2. Mysql常用sql语句(一)- 操作数据库

    21篇测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html ...

  3. 搭建Hadoop集群需要注意的问题:

    搭建Hadoop集群需要注意的问题: 1.检查三台主机名是否正确 2.检查三台IP是否正确 3.检查 /etc/hosts 映射是否正确 4.检查 JDK和Hadoop 是否安装成功(看环境变量配置) ...

  4. 二维线段树 poj-2155

    题意:t组样例 ,输入 n,m,表示n*n的矩阵进行m次操作 ,C: 输入两个坐标 ,组成的矩形 进行取反操作 ,Q:对输的坐标位置输入其值. 思路:一开始想的是用1000(表示x轴)个线段树(对每段 ...

  5. 将java中Map对象转为有相同属性的类对象(json作为中间转换)

    java中Map对象转为有相同属性的类对象(json作为中间转换) 准备好json转换工具类 public class JsonUtil { private static ObjectMapper o ...

  6. 什么情况下JVM内存中的一个对象会被垃圾回收?

    新生代满了会触发 Young GC,老年代满了会触发 Old GC.GC时会回收对象,那么具体是什么样的对象会被垃圾回收器回收呢? 可达性分析算法,判断是否被 GC Roots 引用 判断引用类型:强 ...

  7. WebView的基本使用及相关特性

    WebView 是一个显示网页内容的组件,可以显示网络上的一些在线内容并且可以作为 Web 浏览器滚动显示的内容,它使用 WebKit作为渲染引擎来显示网页,里面包括放大.缩小.执行文本搜索等进行前后 ...

  8. 玩转redis-简单消息队列

    使用go语言基于redis写了一个简单的消息队列 源码地址 使用demo redis的 list 非常的灵活,可以从左边或者右边添加元素,当然也以从任意一头读取数据 添加数据和获取数据的操作也是非常简 ...

  9. 关于C#三层架构增删改查中的“查询”问题

    序:问题总是反复出现,可能只是一个小小的问题,但是就像肉中刺. 问题: 关于“姓名”字段的拼接问题 姓名字段的拼接:this.Repeater1.DataSource = db.GetList(&qu ...

  10. Func 和 Action 委托

    有了泛型委托,就有了一能适用于任何返回类型和任意参数(类型和合理的个数)的通用委托,Func 和 Action.如下所示(下面的in表示参数,out表示返回结果): delegate TResult ...