vue进阶-消息的订阅与发布

📖vue基础学习-组件 介绍了嵌套组件间父子组件通过 props 属性进行传参。子组件传递数据给父组件通过 $emit() 返回自定义事件,父组件调用自定义事件接收子组件返回参数。

📖vue进阶-vue-route 介绍了路由组件传参,两种方式:params传参query 传参

本章介绍组件间通信:✨vue消息的订阅与发布

简介

  • 消息的订阅与发布(PubSub.js)适用于:任何组件间通信
  • PubSub 可以在 Vue 任意组件间进行传值,无需要进行中间层层传递。
  • 使用的模式是观察者模式:生产者抛出,消费者接收。

1. 入门

1.1 安装

npm i pubsub-js

1.2 引入 pubub

import pubsub from 'pubsub-js'

1.3 发布

pubsub.publish('消息名称', 发布的数据)

1.4 订阅

pubsub.subscribe('消息名称', 回调函数)
  • subscribe()方法会返回订阅消息对应的 ID。
  • 回调函数接收两个参数,第一个参数为消息名称,第二个参数为传递过来的数据
  • 回调函数,不建议使用普通匿名函数,因为第三方库和 vue 不一样,不保证函数中的 this 指向 vue 实例或组件实例对象。建议使用箭头函数或者 将普通函数写在 methods 配置项中。

第一种方式:

mounted() {this.pid = pubsub.subscribe('xxx', (msgName, data)=>{...})
}

第二种方式:

methods: {demo(msgName, data){...}
},
mounted() {this.pid = pubsub.subscribe('xxx', this.demo)
}

1.5 取消订阅

beforeDestroy() {pubsub.unsubscribe(this.pid)
}

beforeDestroy 钩子函数中,调用pubsub.unsubscribe取消订阅。

2. 示例

首先,我们先复习下嵌套组件间父子组件传值。

📌1、新增子组件 ComponentA

<template>This is ComponentA, title = {{title}}, userName = {{userName}}
</template>
<script>
export default {props: ['title','userName']
}
</script>

子组件通过 props: ['title','userName'] 显式声明它所接受的属性 titleuserName

📌2、新增父组件 FuComponent

<template><component-a :title="title" :userName="userName"></component-a>
</template><script>
import ComponentA from '@/components/ComponentA.vue'export default {components: { ComponentA },data() {return {title: 'google',userName: 'Jack'}}
}
</script>

父组件在 data 中动态赋值 title、userName 。

📌3、router/index.js配置路由

import { createRouter, createWebHistory } from "vue-router";const routes = [{path: '/fuComponent',component: () => import("@/components/FuComponent.vue")}
]
const router = createRouter({history: createWebHistory(),routes
})
export default router

📌4、App.vue 中使用路由

<template><router-link to="/fuComponent">父子组件参数传递</router-link><br /><hr /><router-view></router-view>
</template>
<script setup></script>

📌5、测试

在这里插入图片描述

3. 发布订阅模式改造

📌1、子组件 ComponentA 发布订阅

在这里插入图片描述

<template>This is ComponentA, title = {{title}}, userName = {{userName}}
</template><script>
import pubsub from "pubsub-js";export default {data() {return {title: '',userName: ''}},mounted() {this.pid = pubsub.subscribe('test', (msgName, data )=> {console.log('有人发布了 test , test 消息的回调执行了', msgName, data);this.title = data.title;this.userName = data.userName;})},beforeDestroy() {pubsub.unsubscribe(this.pid)}
}
</script>

📌2、新增父组件 FuComponent

在这里插入图片描述

<template><component-a></component-a><br /><button @click="send">点击发布消息</button>
</template><script>
import ComponentA from '@/components/ComponentA.vue'
import pubsub from "pubsub-js";export default {components: { ComponentA },methods: {send() {let sendData = {title: "google",userName: "Jack"};pubsub.publish("test", sendData);}}
};
</script>

📌3、测试

🎈点击访问 “http://localhost:8080/fuComponent”
在这里插入图片描述

🎈点击按钮

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/2675.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【conan】本地编译三方库,上传conan服务器

1.6 conan 远程已经编译好的库 conan中文博客&#xff1a; 三方库资源&#xff1a; github conan-io 本地查询 conan search Existing package recipes:b2/4.9.6 boost/1.71.0nolovr/stable bzip2/1.0.8 ceres-solver/2.0.0nolovr/stable eigen/3.3.7nolovr/stable eigen_c…

【软件测试】selenium中元素的定位

1.元素的定位 不管用那种方式&#xff0c;必须保证页面上该属性的唯一性 1.CSS 定位 CSS(Cascading Style Sheets)是一种语言&#xff0c;它被用来描述HTML 和XML 文档的表现。 CSS 使用选择器来为页面元素绑定属性。这些选择器可以被selenium 用作另外的定位策略CSS的获取可…

Go 工具链详解(三): 代码测试神器 go test

go test 作用 go test 是 Go 工具链中的一个命令&#xff0c;用于编译和运行按照要求编写的 Golang 测试代码&#xff0c;并生成测试报告。 要求将测试代码所在的文件命名为 *_test.go&#xff0c;如此命名的文件不会被 go build 命令编译&#xff0c;但是会被 go test 进行编…

C++基础算法前缀和和差分篇

&#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;C算法 &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 主要讲解了前缀和和差分算法 文章目录 Ⅳ. 前缀和 和 差分Ⅵ .Ⅰ前缀和…

echarts_柱状图+漏斗图

目录 柱状图(bar)需求[1] 复制案例[2] 修改类目轴方向[3] 修改数据渲染方向[4] 修改坐标轴文本样式 漏斗图(funnel)漏斗图的形状 柱状图(bar) 需求 如上图&#xff0c;做一个横向柱状图&#xff0c;后端返回的数据是从小向大排列的数据&#xff0c;希望能够按照顺序进行展示。…

【Docker】详解docker安装及使用

详解docker安装及使用 1. 安装docker1.1 查看docker版本信息 2. Docker镜像操作3. Docker容器操作4.知识点总结4.1 docker镜像操作4.2 docker容器操作4.3 docker run启动过程 参见docker基础知识点详解 1. 安装docker 目前Docker只能支持64位系统。 ###关闭和禁止防火墙开机自…

pytorch+CRNN实现

最近接触了一个仪表盘识别的项目&#xff0c;简单调研以后发现可以用CRNN来做。但是手边缺少仪表盘数据集&#xff0c;就先用ICDAR2013试了一下。 结果遇到了一系列坑。为了不使读者和自己在以后的日子继续遭罪。我把正确的代码发到下面了。 1&#xff09;超参数请不要调整&am…

Android oom_adj 详细解读

源码基于&#xff1a;Android R 0. 前言 在博文《oom_adj 内存水位算法剖析》一文中详细的分析了lmkd 中针对 oom_adj 内存水位的计算、使用方法&#xff0c;在博文《oom_adj 更新原理(1)》、《oom_adj 更新原理(2)》中对Android 系统中 oom_adj 的更新原理进行了详细的剖析。…

Linux Shell脚本文件

文章目录 Linux Shell脚本文件vim编辑器vi的使用 认识Bash变量环境变量用户操作变量delcare与typeset 命令的别名与历史命名 正则表达式Shell ScriptsShell Scripts良好习惯第一个shell其他shell例子 - 来自鸟哥linux私房菜语法介绍shell 的调试 Linux Shell脚本文件 vim编辑器…

Centos 7 安装 Oracle 11G

Oracle 11G 安装教程 准备环境 p13390677_112040_Linux-x86-64_1of7.zipp13390677_112040_Linux-x86-64_2of7.zipCentos 7- rhel7-英文版的系统–不想换语言的执行(LANGen_US)– 传输 文件到服务器上 创建用户和组 [rootlocalhost ~]# groupadd oracle [rootlocalhost ~]…

20230715----重返学习-vue3新API-Vue3和Vue2对比-vue3语法-Vue3编码

day-113-one-hundred-and-thirteen-20230715-vue3新API-Vue3和Vue2对比-vue3语法-Vue3编码 vue3新API Vue 3 迁移指南 虚拟DOM 说明:看01视频。虚拟DOM是用于让vue核心代码脱离浏览器的限制&#xff0c;在微信小程序、手机端、canvas之类也有能使用vue语法的可能&#xff0…

Windows11 C盘瘦身

1.符号链接 将大文件夹移动到其他盘&#xff0c;创建成符号链接 2.修改Android Studio路径设置 1.SDK路径 2.Gradle路径 3.模拟器路径 设置环境变量 ANDROID_SDK_HOME

FLutter 开发中 fijkplayer设置屏幕常亮

FLutter 视频播放&#xff1a; 目前在做FLutter种的视频播放功能&#xff0c;遇到了视频播放的时候&#xff0c;屏幕突然黑屏了。网上找了很多&#xff0c;无论是设置在原生的Activity界面&#xff0c;添加如下代码&#xff0c; getWindow().addFlags(WindowManager.LayoutPara…

基于单片机的盲人导航智能拐杖老人防丢防摔倒发短息定位

功能介绍 以STM32单片机作为主控系统&#xff1b; OLED液晶当前实时距离&#xff0c;安全距离&#xff0c;当前经纬度信息&#xff1b;超声波检测小于设置的安全距离&#xff0c;蜂鸣器报警提示&#xff1a;低于安全距离&#xff01;超声波检测当前障碍物距离&#xff0c;GPS进…

虚幻引擎复习笔记

虚幻引擎 宏观了解 工具链&#xff1a;纹理&#xff0c;材质&#xff0c;模型&#xff0c;动画&#xff0c;粒子&#xff0c;地形&#xff0c;声音&#xff0c;光照&#xff0c;毛发&#xff0c;破碎逻辑编写&#xff1a;蓝图可视化脚本&#xff0c;虚幻CGamePlay框架 初次接…

python发送邮件yagmail库

yagmail库发送邮件简洁&#xff0c;代码量少 import yagmaildef send_yagmail(sender, send_password, addressee, hostsmtp.qq.com, port465):yag yagmail.SMTP(sender, send_password, host, port)img_url https://img2.baidu.com/it/u483398814,2966849709&fm253&…

基于单片机的智能空调系统的设计与实现

功能介绍 以51单片机作为主控系统&#xff1b;LCD1602液晶显示当前水温&#xff0c;定时提醒&#xff0c;水量变化DS18B20检测当前水体温度&#xff1b;水位传感器检测当前水位&#xff1b;继电器驱动加热片进行水温加热&#xff1b;定时提醒喝水&#xff0c;蜂鸣器报警&#x…

学习注解的使用模拟RequestMapping解析path

文章目录 前言一、代码部分总结 前言 注解在后端开发过程中提供了许多的便利&#xff0c;提高了代码简洁性和可读性&#xff0c;在应用程序中占据越来越重要的作用&#xff0c;很有学习的必要&#xff0c;接下来会通过代码来完成对类、方法、属性注解的解析。 一、代码部分 p…

LeetCode面试题02.07.链表相交

面试题02.07.链表相交 两种解题思路 面试题02.07.链表相交一、双指针二、哈希集合 一、双指针 这道题简单来说&#xff0c;就是求两个链表交点节点的指针 这里注意&#xff1a;交点不是数值相等&#xff0c;而是指针相等 为了方便举例&#xff0c;假设节点元素数值相等&…

用Python采用Modbus-Tcp的方式读取485电子水尺数据

README.TXT 2023/6/15 V1.0 实现了单个点位数据通信、数据解析、数据存储 2023/6/17 V2.0 实现了多个点位数据通信、数据解析、数据存储 2023/6/19 V2.1 完善log存储&#xff0c;仅保留近3天的log记录&#xff0c;避免不必要的存储&#xff1b;限制log大小&#xff0c;2MB。架…