vue3事件总线mitt使用方式

我的使用场景

在项目中遇到一个这样的问题。页面使用了keepalive缓存, 员工排班和班次之间的数据有关联,当我删除一个班次后,给员工排的班,属于那个被删的班次的情况,已经生效的不会受影响,但是未生效的排班会被删除。如果我不重新拉取后端数据的话,我从班次页面切换到员工排班页面,我前端的排班还是存在的,但是后端的数据已经删除了。这个时候用户点击删除排班,就会出现不友好的提示,我需要避免这个情况。这就需要再删除班次的时候,重新拉取员工排班列表的数据了。

使用方法
安装mitt
复制代码
npm install mitt
创建一个事件总线

在你的项目中创建一个事件总线,可以将其放在一个单独的文件中,例如 eventBus.js

js 复制代码
// eventBus.js
import mitt from 'mitt';
export const eventBus = mitt();
在员工排班中监听事件

监听来自事件总线的事件,然后调用相应的方法,记得要在页面销毁的时候,取消监听。

js 复制代码
// schedule.vue
import { ref, onMounted, onBeforeUnmount } from 'vue';
import { eventBus } from '@/path/to/eventBus';		// 这个路径需要对应上

export default {
  setup() {
    const search = () => {
      // 在这里执行方法
      console.log('方法被调用');
    };

    onMounted(() => {
      eventBus.on('getScheduleSearch', search);
    });

    // 在页面被销毁的时候,取消监听
    onBeforeUnmount(() => {
      eventBus.off('getScheduleSearch', search);
    });

    return {};
  },
};
在班次页面中触发事件

触发事件,通知员工排班页面执行方法。

js 复制代码
// shift.vue
import { ref } from 'vue';
import { eventBus } from '@/path/to/eventBus';		// 这个路径需要对应上

export default {
  setup() {
  	// 假设这是我删除班次的方法
    const deleteShift = () => {
      // 在这里触发事件,通知员工排班页面执行方法。
      eventBus.emit('getScheduleSearch');
    };

    return { getScheduleSearch };
  },
};

这样,你就可以在班次页面中调用 deleteShift 方法时,员工排班页面中的 search 方法就会被触发。这是一种基于事件的简单而灵活的通信方式,适用于不同组件之间的解耦。

相关推荐
ttod_qzstudio20 分钟前
Vue 3 中 toRaw 的取舍之道:以 Babylon.js 3D 开发为例
vue.js·babylonjs
We་ct26 分钟前
LeetCode 15. 三数之和:排序+双指针解法全解析
前端·算法·leetcode·typescript
美狐美颜SDK开放平台26 分钟前
直播场景下抖动特效的实现方案:美颜sdk开发经验分享
前端·人工智能·美颜sdk·直播美颜sdk·视频美颜sdk
草青工作室44 分钟前
java-FreeMarker3.4自定义异常处理
java·前端·python
美狐美颜sdk1 小时前
抖动特效在直播美颜sdk中的实现方式与优化思路
前端·图像处理·人工智能·深度学习·美颜sdk·直播美颜sdk·美颜api
Mr Xu_1 小时前
Vue3 + Element Plus 实战:App 版本管理后台——动态生成下载二维码与封装文件上传
前端·javascript·vue.js
闻哥1 小时前
从 AJAX 到浏览器渲染:前端底层原理与性能指标全解析
java·前端·spring boot·ajax·okhttp·面试
比特森林探险记1 小时前
Vue基础语法与响应式系统详解
前端·javascript·vue.js
m0_694845571 小时前
网站账号太多难管理?Enterr 开源自动化工具搭建教程
运维·服务器·前端·开源·自动化·云计算
光影少年1 小时前
react中redux的connect作用是什么
前端·react.js·前端框架