vue3+ts mitt的使用

javascript 复制代码
安装mitt :npm  i  mitt -S

main.ts:

javascript 复制代码
import  mitt  from  'mitt'
 const  Mit = mitt();
 declare module 'vue' {
  export interface ComponentCustomProperties{
    $Bus:typeof  Mit
  }
}
app.config.globalProperties.$Bus=Mit

在A组件中使用

handlebars 复制代码
<template>
    <div>
     <h1>我是A</h1>
     <button @click="emit">emit</button>
    </div>
</template>
  
<script setup lang='ts'>
  import  {getCurrentInstance } from  "vue";
  const  instance=getCurrentInstance();
  const  emit=  ()=>{
         instance?.proxy?.$Bus.emit("on-xiaoman","你是个小可爱")
  }
</script>
  
<style>
  
</style>

在B组件中使用:

handlebars 复制代码
<template>
    <div>
     <h1>我是B</h1>
    
    </div>
</template>
  
<script setup lang='ts'>
  import  {getCurrentInstance } from  "vue";
  const  instance=getCurrentInstance();
  instance?.proxy?.$Bus.on('on-xiaoman',(str)=>{
console.log(str,'+++++++++B')
  })
</script>
  
<style>
  
</style>

效果:

相关推荐
jiunian_cn39 分钟前
【c++】模板详解
开发语言·c++·visual studio
mpr0xy1 小时前
用Playwright自动化网页测试,不只是“点点点”
运维·javascript·自动化·html5
工藤新一¹2 小时前
C++/SDL 进阶游戏开发 —— 双人塔防(代号:村庄保卫战 19)
开发语言·c++·游戏引擎·游戏开发·sdl
小冯的编程学习之路2 小时前
【C++】:C++17新特性
c语言·开发语言·c++·算法
A_aspectJ3 小时前
【Bootstrap V4系列】学习入门教程之 组件-按钮(Buttons)
javascript·学习·bootstrap
caig0003 小时前
JavaScript性能优化实战
开发语言·javascript·性能优化
爱炸薯条的小朋友3 小时前
C#将Mat或Byte快速转换为Bitmap格式
开发语言·opencv·c#
Tanecious.3 小时前
C++--入门基础
java·开发语言·c++
未来之窗软件服务3 小时前
创意Python爱心代码分享
开发语言·python·仙盟创梦ide·程序员表白
firshman_start4 小时前
第六章,BGP---边界网关协议
开发语言·网络·php