在vue中封裝的彈窗組件使用隊(duì)列模式實(shí)現(xiàn)方法
前言
由于業(yè)務(wù)需要,需要在封裝的彈窗組件中引入定時(shí)器實(shí)現(xiàn)倒計(jì)時(shí)效果,但是如果同時(shí)觸發(fā)兩個(gè)彈窗,就會(huì)導(dǎo)致計(jì)時(shí)器bug,前一個(gè)彈窗的定時(shí)器沒有被清除,倒計(jì)時(shí)就會(huì)錯(cuò)亂,此時(shí)想到的解決辦法就是采用隊(duì)列模式,將每一個(gè)需要的彈窗存到隊(duì)列中,依次的將彈窗展示出來,同時(shí)清除定時(shí)器
什么是隊(duì)列
隊(duì)列(Queue)是先進(jìn)先出(FIFO, First-In-First-Out)的線性表。在具體應(yīng)用中通常用鏈表或者數(shù)組來實(shí)現(xiàn)。隊(duì)列只允許在尾部進(jìn)行插入操作(入隊(duì) enqueue),在頭部進(jìn)行刪除操作(出隊(duì) dequeue)。隊(duì)列的操作方式和堆棧類似,唯一的區(qū)別在于隊(duì)列只允許新數(shù)據(jù)在后端進(jìn)行添加。
JavaScript實(shí)現(xiàn)隊(duì)列的效果
function ArrayQueue(){ var arr = []; //入隊(duì)操作 this.push = function(element){ arr.push(element); return true; } //出隊(duì)操作 this.pop = function(){ return arr.shift(); } //獲取隊(duì)首 this.getFront = function(){ return arr[0]; } //獲取隊(duì)尾 this.getRear = function(){ return arr[arr.length - 1] } //清空隊(duì)列 this.clear = function(){ arr = []; } //獲取隊(duì)長(zhǎng) this.size = function(){ return length; } }
和vue封裝的彈窗組件使用
首先要配合組件封裝隊(duì)列要進(jìn)行修改
class Queue { dataStore = [] constructor(){ this.dataStore=[] } enqueue(e) { this.dataStore.push(e) console.warn('入隊(duì)',this.dataStore); } dequeue() { this.dataStore.shift() console.warn('出隊(duì)',this.dataStore); } front() { console.log(this.dataStore,'front') return this.dataStore[0]() } select(){ return this.dataStore[0] } back() { return this.dataStore[this.dataStore.length - 1] } isEmpty() { if (this.dataStore.length == 0) { return true } return false } toString() { return this.dataStore.join(',') } } export default Queue
在彈出第一個(gè)隊(duì)列的時(shí)候需要自執(zhí)行。
在你的封裝組件的函數(shù)中引入這個(gè)隊(duì)列,同時(shí)實(shí)例化這個(gè)隊(duì)列,寫入兩個(gè)方法.
const pushDialog = (eventName) => { if (queue.isEmpty()) { queue.enqueue(eventName); openDialog(); } else { queue.enqueue(eventName); } } const openDialog = () => { // 打開彈窗 queue.front(); }
在安裝的方法中將每一個(gè)彈窗加入隊(duì)列中
需要注意的是,每個(gè)彈窗是要被銷毀的,不然會(huì)導(dǎo)致方法重復(fù)。
舉例在確認(rèn)方法和定時(shí)器后怎么出隊(duì)列和清空定時(shí)器
到此這篇關(guān)于在vue中封裝的彈窗組件使用隊(duì)列模式實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)vue 封裝的彈窗組件隊(duì)列模式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解Vue.js組件可復(fù)用性的混合(mixin)方式和自定義指令
本篇文章主要介紹了詳解Vue.js組件可復(fù)用性的混合(mixin)方式和自定義指令,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09淺析前端路由簡(jiǎn)介以及vue-router實(shí)現(xiàn)原理
路由就是用來跟后端服務(wù)器進(jìn)行交互的一種方式,通過不同的路徑,來請(qǐng)求不同的資源,請(qǐng)求不同的頁面是路由的其中一種功能。這篇文章主要介紹了前端路由簡(jiǎn)介以及vue-router實(shí)現(xiàn)原理,需要的朋友可以參考下2018-06-06vue使用@scroll監(jiān)聽滾動(dòng)事件時(shí),@scroll無效問題的解決方法詳解
這篇文章主要介紹了vue使用@scroll監(jiān)聽滾動(dòng)事件時(shí),@scroll無效問題的解決方法,結(jié)合實(shí)例形式分析了@scroll監(jiān)聽滾動(dòng)事件無效問題的原因及相應(yīng)的解決方法,需要的朋友可以參考下2019-10-10vue數(shù)據(jù)雙向綁定原理解析(get & set)
這篇文章主要為大家詳細(xì)解析了vue.js數(shù)據(jù)雙向綁定原理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03vue中elementUI表單循環(huán)驗(yàn)證方式
這篇文章主要介紹了vue中elementUI表單循環(huán)驗(yàn)證方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10關(guān)于在Vue中import和require的用法分析
在Vue項(xiàng)目中,我們經(jīng)常需要引入外部的模塊或文件,這時(shí)候就會(huì)用到import和require這兩個(gè)關(guān)鍵字,本文將詳細(xì)分析它們的用法,并提供具體的代碼實(shí)例和解釋,需要的朋友可以參考下2023-06-06vue-element-admin如何設(shè)置默認(rèn)語言
這篇文章主要介紹了vue-element-admin如何設(shè)置默認(rèn)語言,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04