小妙招——dispatchEvent自定义事件

dispatchEvent大家可能接触过,同步派发一个事件,在异步事件之后进行执行。

此处以一个代码片段为例,简单说明一下使用。

javascript 复制代码
<button id="btn">按下按钮</button>
let myBtn = document.querySelector('#btn');
myBtn & myBtn.addEventListener('click', function(){
    document.dispatchEvent(new CustomEvent('clickAfter', {
        detail: {
            more: 'more-info',
            anyKey: 'any key info'
        }
    }))
})
document.addEventListener('clickAfter', (event) => {
    console.log('event', event)
})

点击之后的截图如下

之前在做一个功能(Vue3)的时候,产品忽然想要加一个点击上报。但是因为功能比较复杂,当时拆了好几个组件进行嵌套,关系如下,组件有些数据传递是爷孙之间互传。

即实现组件A和组件C之间的通信

方法一:多次emit()

通过emit一层层传递,A先emit()到B,再emit()到C。

组件A- componentA

javascript 复制代码
<template>
<button @click="onClickAfter">按下点击</button>
</template>
<script lang="ts" setup>
const emit = defineEmits(['onClickAfter'])
const onClickAfter = () => {
 emit('onClickAfter', 12, {p1:12, p2:'click'})
}
</script>

组件B-componentB

javascript 复制代码
<template>
<ComponentA @on-click-after="continueTransfer"></ComponentA>
</template>
<script lang="ts" setup>
const emit = defineEmits(['onToNext'])
const continueTransfer = (firstParams, other) => {
 emit('onToNext', firstParams, other)
}
</script>

组件C-componentC

javascript 复制代码
<template>
<ComponentB @on-to-next="finalReport"></ComponentB>
</template>
<script lang="ts" setup>
const finalReport = (firstParams, other) => {
 console.log('report', firstParams, other)
}
</script>

方法二:dispatchEvent

在A中进行一个dispatchEvent,自定一个事件(new CustomEvent),然后在C中进行监听刚刚自定义的事件即可 组件A- componentA

javascript 复制代码
<template>
<button @click="onClickAfter">按下点击</button>
</template>
<script lang="ts" setup>
const onClickAfter = () => {
    document.dispatchEvent(new CustomEvent('clickAfter', {
        detail: {
            activiyId: 12,
            params: {p1:12, p2:'click'}
        }
    }))
}
</script>

组件C- componentC

javascript 复制代码
<script lang="ts" setup>
onMounted(()=>{
    document.addEventListener('clickAfter', (event) => {
        console.log('event', event)
    })
})
</script>

如果是一个简单的事件,其实完全可以直接使用dispatchEvent,避免了一层层父子通信的麻烦~~~

🔗参考链接

相关推荐
努力的lpp4 分钟前
渗透主流工具完整参数手册(sqlmap、Nmap、Hydra、Dirsearch、Xray)
javascript·网络协议·测试工具·安全·http·工具
problc6 分钟前
用 JavaScript 打开中国的版式文档:@sharp9/ofdjs 诞生记
开发语言·javascript·ecmascript
超哥--7 小时前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
Cutecat_9 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
dsyyyyy110110 小时前
JavaScript变量
开发语言·javascript·ecmascript
qq_4221525710 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen10 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee18611 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct97811 小时前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客11 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop