Vue组件通信_android组件间通信

Vue组件通信_android组件间通信Vue组件通信

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

Vue的组件之间是需要互相通信和传递数据的,这里演示几个常用的通信方式

父与子
  props方式

  props让组件接收外部传过来的数据

   传递数据<组件标签名 name=’***’ :传递参数名=’值’/> 这里传递参数名前加” : ” 从而可以动态绑定数据

   接收数据

       第一种方式(只接收) props:[‘参数名1′,’参数名2’,…….]

      第二种方式 (限制类型) props:{参数名1:参数类型,参数2:参数类型,……}

      第三种方式 (限制类型.限制必要性 指定默认值)

         props:{

                参数1:{

                   type:String(Number,Boolean,Object….) //参数类型

                   required:true, //参数必要性

                   default:’默认值’

     }

}        

注意: props是只读的,vue底层会监测对props的修改,如果进行了修改,就会发出警告 若业务需求确实需要修改那么请复制props的数据到data中,然后可以修改data中的数据

父子组件之间传递数据可以直接使用props方式进行传递,这种方式需要事先在父组件中定义好回调方法,然后在需要的时候让子组件调用就可以
父组件:

   Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

子组件:

自定义事件
还可以使用自定义事件的方式进行传参,这时不需要给子组件像props那样传参,子组件也不用接收

  适用于子组件====>父组件

   使用场景: 子组件想给父组件传数据 那么就要在父组件中给子组件绑定自定义事件(事件的回调在父组件中)

  绑定自定义事件

   a 第一种方式 在父组件中<Demo @事件名=’方法名’/>或<Demo v-on:事件名=’方法’/>

   b 第二种方式 在父组件中 this.$refs.demo.$on(‘事件名’,方法)  (此处的$refs.demo的demo是给子组件起的 ref=’demo’)

   c 若想让自定义事件只触发一次 可以使用once修饰符 或$once方法

   触发自定义事件this.$emit(‘事件名’,数据)

   解绑自定义事件this.$off(‘事件名’)

   组件上也可以绑定原生DOM事件 需要使用native修饰符 @click.native=”show”

   上面绑定自定义事件 即使绑定的是原生事件也会被认为是自定义的 需要加native 加了后就将此事件给组件的根元素

   注意: 通过 this.$refs.xxx.$on(‘事件名’,回调函数) 绑定自定义事件时 回调函数要么配置在methods中 要么使用箭头函数 否则 this指向会出现问题 

第一种写法
               Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 

第二种写法,使用ref

Vue组件通信_android组件间通信

 

子组件中还是以$emit向父组件定义触发事件
父组件使用中定义子组件的ref属性进行获取
      

Vue组件通信_android组件间通信

 

注意: 若想让自定义事件只能触发一次 可以使用once修饰符 或$once方法

触发自定义事件: this.$emit(‘方法名或者事件名’,数据)
解绑自定义事件 this.$off(‘事件名’)
组件上也可以绑定原生Dom事件 需要使用native修饰符
通过this.$refs.xxx.$on(‘方法名’,回调) 绑定自定义事件时 回调要么配置在methods中 要么用箭头函数 否则this指向会出现问题

上述方法只适用于父子组件之间的传递,而不适合任意组件与任意组件之间的传递,比如兄弟组件之间的传递

## 任意组件之间的通信
**全局事件总线**
任意组件的通信vue中提供了全局事件总线来实现

一种可以在任意组件间通信的方式 本质上就是一个对象 必须满足以下条件\

    所有的组件都必须能看到它

   这个对象必须能够使用$on(绑定) $emit(触发) $off(解绑)方法去绑定 触发 和解绑事件

首先安装全局事件总线
       Vue组件通信_android组件间通信

 $bus就是当前应用的vmVue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 

消息订阅与发布
我们除了vue提供的全局事件总线外,我们还可以使用一些第三方库来实现任意组件之间的通信
这里我们使用消息订阅与发布的pubsub-js这个库来实现(消息订阅与发布的第三方库有多种,此处只演示一种,不同库之间的语法也不同)

首先安装第三方库:

Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 Vue组件通信_android组件间通信

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/200687.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • LaTeX入门级教程

    LaTeX入门级教程    LaTeX(LATEX,音译“拉泰赫”)是一种基于ΤΕΧ的排版系统,由美国计算机学家莱斯利·兰伯特(LeslieLamport)在20世纪80年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由TeX所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类…

    2022年7月16日
    13
  • 实验设备管理系统C语言_实验室设备管理系统代码

    实验设备管理系统C语言_实验室设备管理系统代码这里写目录标题实验室设备管理系统题目要求源代码运行结果实验室设备管理系统题目要求实验设备管理系统设计实验设备信息包括:设备编号,设备种类(如:微机、打印机、扫描仪等等),设备名称,设备价格,设备购入日期,是否报废,报废日期等。主要功能:(1)能够完成对设备的录入和修改(2)对设备进行分类统计(3)设备的破损耗费和遗损处理(4)设备的查询要求:使用文件方式存储数据。源代码#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#i

    2022年10月13日
    3
  • maven 打的包在哪_maven打包流程学习「建议收藏」

    maven 打的包在哪_maven打包流程学习「建议收藏」前言:最近工作中遇到了几次跟maven打包相关的问题,每个问题上网查资料解决都花了不少时间,很影响工作进度。既然遇到好几次,每次都能发现知识盲点,干脆总结整理一下,啃掉这个难啃的骨头。ps:最近看到了一个很有意思句子:因为今天不想跑步,所以才去跑,这是长距离跑者的思维方式。转载:正文:还是首先描述一下最近遇到的几个问题吧:一、初见springboot多模块项目mvn打包遇到的问题-存在依赖但却…

    2022年5月11日
    42
  • 归并排序算法详细图解_归并排序算法详解

    归并排序算法详细图解_归并排序算法详解一、什么是归并排序1.概念归并排序(Mergesort)是建立在归并操作上的一种有效的排序算法,归并排序对序列的元素进行逐层折半分组,然后从最小分组开始比较排序,合并成一个大的分组,逐层进行,最终所有的元素都是有序的2.算法原理这是一个无序数列:4、5、8、1、7、2、6、3,我们要将它按从小到大排序。按照归并排序的思想,我们要把序列逐层进行拆分序列逐层拆分如下然后从下往上逐层合并,首先对第一层序列1(只包含元素4)和序列2(只包含元素5)进行合并创建一个大序列,序列长度为两个小序列长度

    2022年10月20日
    2
  • 个人微信api接口调用代码[通俗易懂]

    个人微信api接口调用代码[通俗易懂]个人微信api接口1、微信好友收发消息/***给微信好友发消息*@authorwechatno:tangjinjinwx*@bloghttp://www.wlkankan.cn*/@AsyncpublicvoidhandleMsg(ChannelHandlerContextctx,TransportMessagevo,StringcontentJsonStr){try{…

    2022年10月2日
    3
  • Keil 使用教程(详解)「建议收藏」

    Keil 使用教程(详解)「建议收藏」(1)打开Keil,点击project新建(2)选择合适的型号,没有STC的选项,不要紧,一般C51的好多兼容的(3)不用汇编的话,下面的这个对话框选择否就可以了(4)点击新建一个文件(5)选择保存,并命名为.c(6)双击SourceGroup(7)添加.c文件(8)写完程序后,点击标号1处的按钮,然后点击标号2处的output,依次点击3和4,生成.hex文件…

    2022年5月10日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号