在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 相关文章推荐
js实现对ajax请求面向对象的封装
Jan 08 Javascript
JavaScript实现简洁的俄罗斯方块完整实例
Mar 01 Javascript
jQuery simpleModal插件的使用介绍
Aug 30 Javascript
纯原生js实现table表格的增删
Jan 05 Javascript
深入浅析Node.js单线程模型
Jul 10 Javascript
Angular入口组件(entry component)与声明式组件的区别详解
Apr 09 Javascript
webpack file-loader和url-loader的区别
Jan 15 Javascript
Vue项目安装插件并保存
Jan 28 Javascript
小程序实现多列选择器
Feb 15 Javascript
详解vue-cli3 中跨域解决方案
Apr 10 Javascript
Vue v-model组件封装(类似弹窗组件)
Jan 08 Javascript
vue项目打包后提交到git上为什么没有dist这个文件的解决方法
Sep 16 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 XML备份Mysql数据库
2009/05/27 PHP
PHP分页类集锦
2014/11/18 PHP
PHP发送短信代码分享
2015/08/11 PHP
微信公众平台开发之天气预报功能
2015/08/31 PHP
Joomla使用Apache重写模式的方法
2016/05/04 PHP
微信支付之JSAPI公众号支付详解
2019/05/15 PHP
jQuery选中select控件 无法设置selected的解决方法
2010/09/01 Javascript
jQuery-onload让第一次页面加载时图片是淡入方式显示
2012/05/23 Javascript
FF火狐下获取一个元素同类型的相邻元素实现代码
2012/12/15 Javascript
jQuery中filter()方法用法实例
2015/01/06 Javascript
jQuery对象初始化的传参方式
2015/02/26 Javascript
jQuery对象与DOM对象转换方法详解
2016/05/10 Javascript
浅谈layer的iframe弹窗给里面的标签赋值的问题
2016/11/10 Javascript
Javascript中引用类型传递的知识点小结
2017/03/06 Javascript
json的结构与遍历方法实例分析
2017/04/25 Javascript
Angular2+如何去除url中的#号详解
2017/12/20 Javascript
代码详解JS操作剪贴板
2018/02/11 Javascript
vue+iview实现分页及查询功能
2020/11/17 Vue.js
python处理cookie详解
2014/02/07 Python
使用python实现rsa算法代码
2016/02/17 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
Python测试Kafka集群(pykafka)实例
2019/12/23 Python
Python解析微信dat文件的方法
2020/11/30 Python
韩国最大的购物网站:Gmarket
2019/06/20 全球购物
小学教师岗位职责
2013/11/25 职场文书
读书心得体会
2013/12/28 职场文书
金融专业大学生自我评价
2014/01/09 职场文书
2014年学校团委工作总结
2014/12/20 职场文书
检察院起诉意见书
2015/05/20 职场文书
欠条样本
2015/07/03 职场文书
教师远程培训心得体会
2016/01/09 职场文书
2016大学生暑期社会实践心得体会
2016/01/14 职场文书
广告文案的撰写技巧(实用干货)
2019/08/23 职场文书
读《推着妈妈去旅行》有感1500字
2019/10/15 职场文书
导游词之永济鹳雀楼
2020/01/16 职场文书
mysql 子查询的使用
2022/04/28 MySQL