Vue3基础(23)___vue3非父子组件之间的通信

简介: 本文介绍了Vue 3中非父子组件间通信的方法,通过创建一个事件集合对象和相应的触发监听函数,实现跨组件的事件传递和监听。

父子传值可以看这个:

Vue3基础(十san)___父子组件通信___props、emit___provide、inject

非父子传值:

写一个事件集合对象,并写模拟触发函数、监听函数:
evnetList:事件集合对象数组;
name:每一个事件的标识;
callbackFun:回调函数;

const eventObj = {
    evnetList: [],
    on(callbackFun, name) {
        this.evnetList.push({
            name,
            callbackFun
        })
    },
    emit(name, data) {
        this.evnetList.forEach(element => {
            if (name === element.name) {
                element.callbackFun(data)
            }
        });
    }
}
export default eventObj
AI 代码解读

组件A触发事件:

import eventFun from "@/eventFun";
eventFun.emit("changeUsernameP",'我是组件A传递的参数字符串')
AI 代码解读

组件B:监听事件

import eventFun from "@/eventFun";
import {  onMounted } from "vue";
    onMounted(() => {
      eventFun.on((str) => {
        console.log(str);
        //触发事件后的具体操作...
         ......
      }, "changeUsernameP");
    });
AI 代码解读
目录
打赏
0
0
0
0
95
分享
相关文章
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
高效工作流:用Mermaid绘制你的专属流程图;如何在Vue3中导入mermaid绘制流程图
mermaid是一款非常优秀的基于 JavaScript 的图表绘制工具,可渲染 Markdown 启发的文本定义以动态创建和修改图表。非常适合新手学习或者做一些弱交互且自定义要求不高的图表 除了流程图以外,mermaid还支持序列图、类图、状态图、实体关系图等图表可供探索。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
vue父子组件及非父子组件通信
vue父子组件及非父子组件通信
157 0
vue父子组件通信以及非父子组件通信的方法
vue父子组件通信以及非父子组件通信的方法
165 0
vue父子组件通信以及非父子组件通信的方法
Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
284 0
Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
总结Vue第二天:自定义子组件、父子组件通信、插槽
总结Vue第二天:自定义子组件、父子组件通信、插槽
226 0
总结Vue第二天:自定义子组件、父子组件通信、插槽
Vue 通过props实现父子组件通信
本文目录 1. 前言 2. 开发新闻列表父组件 3. 开发新闻内容子组件 4. 小结
146 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等