在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编辑器和代码格式化
Apr 25 Javascript
Extjs单独定义各组件的实例代码
Jun 25 Javascript
JavaScript中instanceof运算符的用法总结
Nov 19 Javascript
javascript模拟命名空间
Apr 17 Javascript
批量下载对路网图片并生成html的实现方法
Jun 07 Javascript
node.js实现回调的方法示例
Mar 01 Javascript
详解Vue.js之视图和数据的双向绑定(v-model)
Jun 23 Javascript
json前后端数据交互相关代码
Sep 19 Javascript
npm 常用命令详解(小结)
Jan 17 Javascript
Vue中keep-alive 实现后退不刷新并保持滚动位置
Mar 17 Javascript
解决vue net :ERR_CONNECTION_REFUSED报错问题
Aug 13 Javascript
vue使用Sass时报错问题的解决方法
Oct 14 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
基于mysql的bbs设计(二)
2006/10/09 PHP
memcached 和 mysql 主从环境下php开发代码详解
2010/05/16 PHP
如何让CI框架支持service层
2014/10/29 PHP
在PHP站点的页面上添加Facebook评论插件的实例教程
2016/01/08 PHP
jQuery建立一个按字母顺序排列的友好页面索引(兼容IE6/7/8)
2013/02/26 Javascript
谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
2015/10/01 Javascript
jQuery日期范围选择器附源码下载
2017/05/23 jQuery
AngularJS实现的JSONP跨域访问数据传输功能详解
2017/07/20 Javascript
详解A标签中href=""的几种用法
2017/08/20 Javascript
vue-cli脚手架config目录下index.js配置文件的方法
2018/03/13 Javascript
如何以Angular的姿势打开Font-Awesome详解
2018/04/22 Javascript
es6新特性之 class 基本用法解析
2018/05/05 Javascript
vuejs移动端实现div拖拽移动
2019/07/25 Javascript
如何基于js判断浏览器版本
2020/02/20 Javascript
vue-resource post数据时碰到Django csrf问题的解决
2020/03/13 Javascript
el-form 多层级表单的实现示例
2020/09/10 Javascript
教你安装python Django(图文)
2013/11/04 Python
利用python批量检查网站的可用性
2016/09/09 Python
python如何为被装饰的函数保留元数据
2018/03/21 Python
使用Django和Python创建Json response的方法
2018/03/26 Python
python 删除指定时间间隔之前的文件实例
2018/04/24 Python
Python根据已知邻接矩阵绘制无向图操作示例
2018/06/23 Python
python使用Matplotlib绘制分段函数
2018/09/25 Python
python中web框架的自定义创建
2019/09/08 Python
python 的 openpyxl模块 读取 Excel文件的方法
2019/09/09 Python
python模块导入的方法
2019/10/24 Python
python中return如何写
2020/06/18 Python
HTML5移动端手机网站开发流程
2016/04/25 HTML / CSS
教师党性分析材料
2014/02/04 职场文书
物流专业求职信
2014/06/30 职场文书
代领报检证委托书范本
2014/10/11 职场文书
公积金贷款承诺书
2015/04/30 职场文书
趣味运动会口号
2015/12/24 职场文书
golang 实现Location跳转方式
2021/05/02 Golang
Oracle中DBLink的详细介绍
2022/04/29 Oracle
MySQL外键约束(Foreign Key)案例详解
2022/06/28 MySQL