当前位置: 首页 > news >正文

Vue的ubus emit/on使用

这段代码是 Vue.js 组件中的 mounted 生命周期钩子函数,主要作用是监听一个名为 “macSelectData” 的全局事件。具体行为如下:


分步解释:

  1. mounted() 生命周期钩子
    当组件被挂载到 DOM 后,Vue 会自动调用 mounted() 方法。这里常用于初始化操作,比如数据请求、事件监听等。

  2. this.$bus.on("macSelectData", this.open)

    • this.$bus:通常指通过 Vue 实例实现的事件总线(Event Bus),用于跨组件通信(非父子组件)。
    • .on("macSelectData", this.open):监听名为 "macSelectData" 的自定义事件,当该事件被触发时,调用组件的 open 方法。

实际作用:

  • 当其他组件或代码通过 this.$bus.emit("macSelectData", data) 触发事件时,当前组件的 open 方法会被调用,并可能接收到传递的 data 参数。
  • 典型场景:比如一个 MAC 地址选择组件选中某个地址后,通过事件总线通知当前组件打开弹窗或更新数据。

潜在注意事项:

  1. 内存泄漏风险
    如果组件销毁前未移除事件监听(需在 beforeDestroy 中调用 this.$bus.off("macSelectData", this.open)),可能导致重复监听或调用已销毁组件的方法。

  2. 事件总线设计
    $bus 通常是全局 Vue 实例(如 new Vue()),需确保项目中已正确初始化事件总线。


示例流程:

// 组件 A 触发事件
this.$bus.emit("macSelectData", { mac: "00:1A:2B:3C:4D:5E" });// 当前组件(包含上述代码)的 open 方法被调用
methods: {open(data) {console.log(data.mac); // 输出 "00:1A:2B:3C:4D:5E"// 执行打开弹窗等操作}
}

如果需要进一步优化,建议添加事件监听的移除逻辑以避免潜在问题。

http://www.dtcms.com/a/292560.html

相关文章:

  • 嵌入式 Qt 开发:实现开机 Logo 和无操作自动锁屏
  • 项目集成zustand后,如何构建和使用,以及devtools函数。
  • 新能源工厂的可视化碳中和实验:碳足迹追踪看板与能源调度策略仿真
  • React 项目性能瓶颈分析
  • SCSAI项目管理智能体设计方案核心设计思路:分层开放架构
  • GitOps实践:基于Argo CD的Kubernetes集群应用持续交付实战指南
  • 智慧能源驱动数字孪生重介选煤新模式探索
  • 力扣 78.子集
  • 【element-ui el-table】多选表格勾选时默认勾选了全部,row-key绑定异常问题解决
  • EasyMan 数字人服务全面焕新,交互型AI数字人助推孪生体验全新升级
  • 等保2.0详解:筑牢数字时代安全基石
  • 【GIT】基础知识及基本应用
  • 如何加固Endpoint Central服务器的安全?(上)
  • Linux驱动-中断-共享队列
  • 【size_t 类型转换】ans = max(ans, (int)occ.size());
  • 公司内部网址怎么在外网打开?如何让外网访问内网的网站呢?
  • qtbase5-dev库使用介绍
  • 5.6 指令流水线 (答案见原书 P267)
  • windows10设置了软件开机自启,为啥不自启动
  • iOS 抓包工具有哪些?场景导向下的工具推荐与实战对比
  • Vue3 面试题及详细答案120道(16-30 )
  • SonarQube+Git
  • Dify-13: 文本生成API端点
  • 使用mybatis实现模糊查询和精准查询切换的功能
  • Cy3-NH2 花菁染料Cy3-氨基,星戈瑞
  • CMOS知识点 物理气相沉积
  • ECMAScript(简称 ES)和 JavaScript 的关系
  • Qt文件操作:读写文件的各种方法
  • 如何安装没有install.exe的mysql数据库文件
  • uniapp打开导航软件并定位到目标位置的实现