欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ的示例詳解

 更新時(shí)間:2024年02月27日 08:43:32   作者:大陽(yáng)光男孩  
這篇文章為大家詳細(xì)主要介紹了如何基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ, 讓消息延遲消費(fèi)或者做緩存,文中的示例代碼講解詳細(xì),需要的可以參考一下

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ù)傳播的方法

    今天小編就為大家分享一篇vue click.stop阻止點(diǎn)擊事件繼續(xù)傳播的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 詳解vue mint-ui源碼解析之loadmore組件

    詳解vue mint-ui源碼解析之loadmore組件

    本篇文章主要介紹了vue mint-ui源碼解析之loadmore組件,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • Vue中mixins的使用方法以及實(shí)際項(xiàng)目應(yīng)用指南

    Vue中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-03
  • vue 中swiper的使用教程

    vue 中swiper的使用教程

    本文通過(guò)實(shí)例代碼給大家介紹了vue 中swiper的使用,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • vue3中的hook簡(jiǎn)單封裝

    vue3中的hook簡(jiǎn)單封裝

    這篇文章主要介紹了vue3中的hook簡(jiǎn)單封裝,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 前端之vue3使用WebSocket的詳細(xì)步驟

    前端之vue3使用WebSocket的詳細(xì)步驟

    websocket實(shí)現(xiàn)的全雙工通信,真真太香了,下面這篇文章主要給大家介紹了關(guān)于前端之vue3使用WebSocket的詳細(xì)步驟,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue對(duì)枚舉值轉(zhuǎn)換方式

    vue對(duì)枚舉值轉(zhuǎn)換方式

    這篇文章主要介紹了vue對(duì)枚舉值轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue3中關(guān)于i18n字符串轉(zhuǎn)義問(wèn)題

    vue3中關(guān)于i18n字符串轉(zhuǎn)義問(wèn)題

    這篇文章主要介紹了vue3中關(guān)于i18n字符串轉(zhuǎn)義問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Vue3使用Lottie實(shí)現(xiàn)一個(gè)簡(jiǎn)單的加載動(dòng)畫(huà)

    Vue3使用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-02
  • vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例

    vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例

    本文主要介紹了vue實(shí)現(xiàn)GitHub的第三方授權(quán),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11

最新評(píng)論