在vue中封装的弹窗组件使用队列模式实现方法


Posted in Javascript onJuly 23, 2020

前言

由于业务需要,需要在封装的弹窗组件中引入定时器实现倒计时效果,但是如果同时触发两个弹窗,就会导致计时器bug,前一个弹窗的定时器没有被清除,倒计时就会错乱,此时想到的解决办法就是采用队列模式,将每一个需要的弹窗存到队列中,依次的将弹窗展示出来,同时清除定时器

什么是队列

队列(Queue)是先进先出(FIFO, First-In-First-Out)的线性表。在具体应用中通常用链表或者数组来实现。队列只允许在尾部进行插入操作(入队 enqueue),在头部进行删除操作(出队 dequeue)。队列的操作方式和堆栈类似,唯一的区别在于队列只允许新数据在后端进行添加。

JavaScript实现队列的效果

function ArrayQueue(){ 
  var arr = []; 
    //入队操作 
  this.push = function(element){ 
    arr.push(element); 
    return true; 
  } 
    //出队操作 
  this.pop = function(){ 
    return arr.shift(); 
  } 
    //获取队首 
  this.getFront = function(){ 
    return arr[0]; 
  } 
    //获取队尾 
  this.getRear = function(){ 
    return arr[arr.length - 1] 
  } 
    //清空队列 
  this.clear = function(){ 
    arr = []; 
  } 
    //获取队长 
  this.size = function(){ 
    return length; 
  } 
}

和vue封装的弹窗组件使用

首先要配合组件封装队列要进行修改

class Queue {
 dataStore = []
 constructor(){
  this.dataStore=[]
 }
 enqueue(e) {
  this.dataStore.push(e)
  console.warn('入队',this.dataStore);
 }

 dequeue() {
  this.dataStore.shift()
  console.warn('出队',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

在弹出第一个队列的时候需要自执行。

在你的封装组件的函数中引入这个队列,同时实例化这个队列,写入两个方法.

const pushDialog = (eventName) => {
 if (queue.isEmpty()) {
  queue.enqueue(eventName);
  openDialog();
 } else {
  queue.enqueue(eventName);
 }
}
const openDialog = () => {
 // 打开弹窗
 queue.front();
}

在安装的方法中将每一个弹窗加入队列中

在vue中封装的弹窗组件使用队列模式实现方法

需要注意的是,每个弹窗是要被销毁的,不然会导致方法重复。

举例在确认方法和定时器后怎么出队列和清空定时器

在vue中封装的弹窗组件使用队列模式实现方法

到此这篇关于在vue中封装的弹窗组件使用队列模式实现的文章就介绍到这了,更多相关vue 封装的弹窗组件队列模式内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
textarea的value是html文件源代码,存成html文件的代码
Apr 20 Javascript
js 替换
Feb 19 Javascript
php与js的区别是什么
Aug 05 Javascript
jQuery自动切换/点击切换选项卡效果的小例子
Aug 12 Javascript
解决jquery操作checkbox火狐下第二次无法勾选问题
Feb 10 Javascript
JS 打印界面的CSS居中代码适用所有浏览器
Mar 19 Javascript
使用jQuery实现图片遮罩半透明坠落遮挡
Mar 16 Javascript
Ionic实现仿通讯录点击滑动及$ionicscrolldelegate使用分析
Jan 18 Javascript
浅谈jQuery中的checkbox问题
Aug 10 Javascript
js时间戳和c#时间戳互转方法(推荐)
Feb 15 Javascript
JS+CSS实现下拉刷新/上拉加载插件
Mar 31 Javascript
基于leaflet.js实现修改地图主题样式的流程分析
May 15 Javascript
基于JS实现计算24点算法代码实例解析
Jul 23 #Javascript
javascript递归函数定义和用法示例分析
Jul 22 #Javascript
简单了解vue 插值表达式Mustache
Jul 22 #Javascript
详解node.js 事件循环
Jul 22 #Javascript
jQuery+ThinkPHP实现图片上传
Jul 23 #jQuery
详解vue中v-on事件监听指令的基本用法
Jul 22 #Javascript
使用vue实现通过变量动态拼接url
Jul 22 #Javascript
You might like
很温暖很温暖的Lester Young
2021/03/03 冲泡冲煮
又十个超级有用的PHP代码片段
2015/09/24 PHP
LINUX下PHP程序实现WORD文件转化为PDF文件的方法
2016/05/13 PHP
PHP explode()函数用法讲解
2019/02/15 PHP
[原创]网络复制内容时常用的正则+editplus
2006/11/30 Javascript
jquery异步请求实例代码
2011/06/21 Javascript
JavaScript中获取鼠标位置相关属性总结
2014/10/11 Javascript
jQuery简单实现QQ空间点赞已经取消点赞
2015/04/02 Javascript
JavaScript 匿名函数和闭包介绍
2015/04/13 Javascript
jquery ajax 如何向jsp提交表单数据
2015/08/23 Javascript
关于获取DIV内部内容报错的原因分析及解决办法
2016/01/29 Javascript
基于BootStarp的Dailog
2016/04/28 Javascript
JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL错误的解决方法
2016/08/19 Javascript
JavaScript lodash常见用法系列小结
2016/08/24 Javascript
Jquery Easyui分割按钮组件SplitButton使用详解(17)
2016/12/18 Javascript
jQuery中的一些小技巧
2017/01/18 Javascript
基于jQuery实现咖啡订单管理简单应用
2017/02/10 Javascript
原生JS与jQuery编写简单选项卡
2017/10/30 jQuery
javascript按顺序加载运行js方法
2017/12/01 Javascript
React Native中NavigatorIOS组件的简单使用详解
2018/01/27 Javascript
详解vue中async-await的使用误区
2018/12/05 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
Python 命令行参数sys.argv
2008/09/06 Python
简单上手Python中装饰器的使用
2015/07/12 Python
numpy使用技巧之数组过滤实例代码
2018/02/03 Python
解决项目pycharm能运行,在终端却无法运行的问题
2019/01/19 Python
不同浏览器对CSS3和HTML5的支持状况
2009/10/31 HTML / CSS
美国首屈一指的礼品篮供应商:GiftTree
2018/01/06 全球购物
有个性的自我评价范文
2013/11/15 职场文书
公司外出活动方案
2014/08/14 职场文书
股东出资证明书(正规版)
2014/09/24 职场文书
副总经理党的群众路线教育实践活动个人对照检查材料思想汇报
2014/10/06 职场文书
国际残疾人日广播稿范文
2014/10/09 职场文书
2014年科协工作总结
2014/12/09 职场文书
2015年求职自荐信范文
2015/03/04 职场文书
mysql 带多个条件的查询方式
2021/06/05 MySQL