基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ的示例詳解
MQ功能實(shí)現(xiàn)的具體代碼(TsMQ.ts):
import { v4 as uuidx } from 'uuid'; import emitter from '@/utils/mitt' class Message { // 過(guò)期時(shí)間,0表示馬上就消費(fèi) exp: number; // 消費(fèi)標(biāo)識(shí),避免重復(fù)消費(fèi) tag : string; // 消息體 body : any; constructor( exp: number , body : any ) { if (exp == 0) { this.exp = 0; }else { this.exp = Date.now().valueOf() + exp; } this.body = body; this.tag = uuidx(); } } export default class TsMQ { static tsMQ : TsMQ; repository : Map<string, any[]>; /* 獲取單列的MQ對(duì)象 */ static getInstance() : TsMQ { if(this.tsMQ == null) { this.tsMQ = new TsMQ(); } return this.tsMQ; } constructor() { this.repository = new Map<string,any[]>(); // 把消息放入Mitt進(jìn)行推送 setInterval(()=> { Array.from(this.repository.keys()).forEach( key => { let poll = this.repository.get(key) as any[]; if(poll.length > 0) { poll.forEach( item => { if (item.exp == 0 || item.exp <= Date.now().valueOf() - 100) { emitter.emit(key,item.body); let single : any[] = this.repository.get(key) as any[]; single = single.filter(dispose => { return dispose.tag !== item.tag; }); this.repository.set(key,single); } }); } }); },100) } /* * @describe 放消息入隊(duì)列 * @param queue : string 隊(duì)列名稱 * @param exp : number 消息消費(fèi)時(shí)間 * @param message : any 消息體 */ pushMessage( queue : string , exp : number, message : any ) { if(this.repository.has(queue)) { let single : any[] = this.repository.get(queue) as any[]; single.push(new Message(exp,message)); this.repository.set(queue,single); }else { let temp = []; temp.push(new Message(exp,message)); this.repository.set(queue,temp); } } /* * 直接獲取消息,可以配合做本地緩存 * 就要去掉constructor的輪詢推送 */ takeMessage( queue : string ) : any { let single : any[] = this.repository.get(queue) as any[]; if( single && single.length > 0) { let message = single.shift(); this.repository.set(queue,single); return message; }else { return '隊(duì)列沒(méi)有消息!'; } } }
提示:其中需要用到三方的uuid和mitt,然后要消息持久化可以用到pinia來(lái)讓消息持久化,本案列沒(méi)有采用持久化
uuid的三方包安裝命令
npm install uuid
使用方式:
<script setup lang="ts"> import TsMQ from '@/utils/TsMQ' import emitter from '@/utils/mitt' let tsMQ : TsMQ = TsMQ.getInstance(); //訂閱消息 emitter.on("HelloWord",e => { console.log(`收到消息:${JSON.stringify(e)}\n消息時(shí)間:${new Date().toLocaleString()}`) }) //投送消息 function tsMQs() { console.log(`M2投遞時(shí)間:${new Date().toLocaleString()}`) tsMQ.pushMessage("HelloWord",1000 * 20,{ name : 'M2', second:20 }); tsMQ.pushMessage("HelloWord",1000 * 3,{ name : 'M1', second:3 }); // MQ功能實(shí)現(xiàn)的具體代碼,提示:其中需要用到三方的uuid和mitt,然后要消息持久化可以用到pinia來(lái)讓消息持久化,本案列沒(méi)有采用持久化 } function takeMQs() { console.log(tsMQ.takeMessage('1')); } </script> <template> <div id="app" style="display: flex;flex-direction: column;justify-content: center;height: 100%;width: 100%;margin: 0;padding: 0"> <span @click="tsMQs">MQ投送</span> <span @click="takeMQs">MQ獲取</span> </div> </template> <style scoped> </style>
效果:
總結(jié):我們可以看到我們實(shí)現(xiàn)了這個(gè)功能 ,其中可以用來(lái)作為緩存使用,同理可寫(xiě)
到此這篇關(guān)于基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ的示例詳解的文章就介紹到這了,更多相關(guān)Vue本地消息隊(duì)列MQ內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue click.stop阻止點(diǎn)擊事件繼續(xù)傳播的方法
今天小編就為大家分享一篇vue click.stop阻止點(diǎn)擊事件繼續(xù)傳播的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09Vue中mixins的使用方法以及實(shí)際項(xiàng)目應(yīng)用指南
vue中提供了一種混合機(jī)制--mixins,用來(lái)更高效的實(shí)現(xiàn)組件內(nèi)容的復(fù)用,下面這篇文章主要給大家介紹了關(guān)于Vue中mixins的使用方法以及實(shí)際項(xiàng)目應(yīng)用指南,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03vue3中關(guān)于i18n字符串轉(zhuǎn)義問(wèn)題
這篇文章主要介紹了vue3中關(guān)于i18n字符串轉(zhuǎn)義問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04Vue3使用Lottie實(shí)現(xiàn)一個(gè)簡(jiǎn)單的加載動(dòng)畫(huà)
Lottie 是一個(gè)流行的動(dòng)畫(huà)庫(kù),它允許我們使用 JSON 文件來(lái)渲染高質(zhì)量的動(dòng)畫(huà),本文將介紹一下如何在Vue3中集成 Lottie 動(dòng)畫(huà)實(shí)現(xiàn)一個(gè)加載動(dòng)畫(huà)效果,需要的可以了解下2025-02-02vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例
本文主要介紹了vue實(shí)現(xiàn)GitHub的第三方授權(quán),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11