born.to.like 2023-09-24 20:31 采纳率: 0%
浏览 29

vue3中使用 mitt 遇到问题

main.ts 中:

import mitt from "mitt"

const Mit = mitt()

declare module "vue" {
    export interface ComponentCustomProperties {
        $Bus: typeof Mit 
    }
}

const app = createApp(App)
app.config.globalProperties.$Bus = Mit

页面中监听事件时报错:

import { getCurrentInstance, onUnmounted } from 'vue'
const instance = getCurrentInstance() // 获取组件实例

const callback = (val: string) => {
    return console.log('接收到的数据val: ', val);
}
instance?.proxy?.$Bus.on("on-click2", callback) // 注册事件监听

onUnmounted(() => {
    instance?.proxy?.$Bus.off("on-click2", callback) // 删除事件监听
})

报错:

没有与此调用匹配的重载。
  第 1 个重载(共 2 个),“(type: "*", handler: WildcardHandler<Record<EventType, unknown>>): void | undefined”,出现以下错误。
  第 2 个重载(共 2 个),“(type: "on-click2", handler: Handler<unknown>): void | undefined”,出现以下错误。ts(2769)

  • 写回答

3条回答 默认 最新

  • born.to.like 2023-10-05 22:48
    关注

    终于解决了,原来是需要给 callback 标注类型:

    
    
    type handler = Handler<any>
    const callback: handler = (val: string) => {}
    
    
    
    评论

报告相同问题?

问题事件

  • 修改了问题 10月5日
  • 创建了问题 9月24日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表