在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 相关文章推荐
javascript 函数式编程
Aug 16 Javascript
javascript限制文本框只允许输入数字(曾经与现在的方法对比)
Jan 18 Javascript
jquery实现弹出层遮罩效果的简单实例
Mar 03 Javascript
Node.js文件操作详解
Aug 16 Javascript
纯JS实现本地图片预览的方法
Jul 31 Javascript
使用jQuery Mobile框架开发移动端Web App的入门教程
May 17 Javascript
prototype与__proto__区别详细介绍
Jan 09 Javascript
JS中的作用域链
Mar 01 Javascript
js将当前时间格式化为 年-月-日 时:分:秒的实现代码
Jan 20 Javascript
vue项目引入Iconfont图标库的教程图解
Oct 24 Javascript
js自定义input文件上传样式
Oct 26 Javascript
javascript实现计算器功能
Mar 30 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
PHP mail 通过Windows的SMTP发送邮件失败的解决方案
2009/05/27 PHP
体育彩票排列三组选三算法分享
2014/03/07 PHP
php删除文本文件中重复行的方法
2015/04/28 PHP
php实现简易聊天室应用代码
2015/09/23 PHP
一个对于Array的简单扩展
2006/10/03 Javascript
在vs2010中调试javascript代码方法
2011/02/11 Javascript
瀑布流布局并自动加载实现代码
2013/03/12 Javascript
jquery 实现窗口的最大化不论什么情况
2013/09/03 Javascript
js实现收缩菜单效果实例代码
2013/10/30 Javascript
无闪烁更新网页内容JS实现
2013/12/19 Javascript
原生javaScript实现图片延时加载的方法
2014/12/22 Javascript
浅谈jQuery.easyui的datebox格式化时间
2015/06/25 Javascript
JavaScript tab选项卡插件实例代码
2016/02/23 Javascript
微信小程序 视图层(xx.xml)和逻辑层(xx.js)详细介绍
2016/10/13 Javascript
jQuery UI仿淘宝搜索下拉列表功能
2017/01/10 Javascript
jQuery操作选中select下拉框的值代码实例
2020/02/07 jQuery
eslint+prettier统一代码风格的实现方法
2020/07/22 Javascript
[01:34]2014DOTA2展望TI 剑指西雅图VG战队专访
2014/06/30 DOTA
下载糗事百科的内容_python版
2008/12/07 Python
Python实现全角半角转换的方法
2014/08/18 Python
Python获取DLL和EXE文件版本号的方法
2015/03/10 Python
Python与Redis的连接教程
2015/04/22 Python
Python输出PowerPoint(ppt)文件中全部文字信息的方法
2015/04/28 Python
python制作websocket服务器实例分享
2016/11/20 Python
TensorFlow中权重的随机初始化的方法
2018/02/11 Python
python爬虫中多线程的使用详解
2019/09/23 Python
在Anaconda3下使用清华镜像源安装TensorFlow(CPU版)
2020/04/19 Python
使用pytorch 筛选出一定范围的值
2020/06/28 Python
英语自我评价范文
2014/01/24 职场文书
公司活动邀请函
2014/01/24 职场文书
电气自动化个人求职信范文
2014/02/03 职场文书
产品质量承诺范本
2014/03/31 职场文书
中国入世承诺
2014/04/01 职场文书
小学二年级评语
2014/04/21 职场文书
民主生活会对照检查材料思想汇报
2014/09/27 职场文书
初中班干部工作总结
2015/08/10 职场文书