这个问题,困扰我很久很久

怎么实现的呢?首先进入页面就开始调取打印接口,打印接口的成功回调函数里面写

this.hasOut++(这是实时显示的数量)
this.width=(this.hasOut/this.totalNumber)*100+ '%'(这是进度条的宽度) 然后去写watch 监听这个数量的变化(这个hasOut实在data中什么了的)
watch: {
hasOut(val) {
if(val<localStorage.getItem('buyNumber')){
this.$nextTick(() => {
this.testPrint(val)//这是打印函数
});
}else {
          //跳转到首页(打印完之后)
this.$router.push({
name:'index',
})
}
}

但是上面这么写,不能实现打印的票数实时变化,直到打印完了之后,页面才会显示已打印 10张(假如买了10张)

这个怎么办呢?

直接来核心代码,加入了setTimeOut

if(bb==0||bb==8){
// 0 8 代表打印成功
setTimeout(()=>{
this.hasOut++
this.width=(this.hasOut/this.totalNumber)*100+ '%'
},0)
}

watch也要写  不然hasOut变化太快,有时候就不会实时变化,它会跳过 比如打印1张直接跳转到3张中间的2没显示

  watch: {
hasOut(val) {
if(val<localStorage.getItem('buyNumber')){
          
setTimeout(()=>{
this.$nextTick(() => {
this.testPrint(val)
});
},0)
}else {
//这里也写timeout是因为 不写的话 比如你买10张,它只会显示已打印9张,进度条也是90% 然后就直接跳首页了
setTimeout(()=>{
this.$router.push({
name:'index',
})
},1500) }
}
},

综上所述,小知识--》就是你setTimeout设置为0,其实不起作用,因为浏览器js执行有个最小时间间隔,每个浏览器不通,一般都是15毫秒左右,有低的也有高的,差不多就这个值。

理一下思路,进入页面--》打印接口--》成功--》setTimeout--》0秒后(其实是15毫秒后,不通浏览器时间间隔不通)数量++--》watch监听到数量变化--》0秒(15ms)后,调取打印接口--》循环。

说白了就相当于同步了;任务队列显示打印成功回调的setTimeout,这个++执行后,watch监听到小于buyNumber,然后setTimeout 调取打印接口,然后循环,为啥watch中要写setTimeout呢,因为任务队列啊,写了就会去排队,不写的话,它就有可能插队,写了就能保证这个任务队列是处于同步的状态啊-------》哈哈哈哈哈这么写你理解了涩


JavaScript引擎是单线程运行的,浏览器无论在什么时候都只且只有一个线程在运行JavaScript程序.浏览器内核实现允许多个线程异步执行,这些线程在内核制控下相互配合以保持同步
如果队列非空,引擎就从队列头取出一个任务,直到该任务处理完,即返回后引擎接着运行下一个任务,在任务没返回前队列中的其它任务是没法被执行的.

vue中打印显示++的问题解决方案(做成类似同步的操作就行了)的更多相关文章

  1. 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据

    前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...

  2. AndroidListview 滑动过程中图片显示重复错乱解决方案

    主要分析Android中Listview滚动过程造成的图片显示重复.错乱.闪烁的原因及解决方法,顺便跟进Listview的缓存机制. 1.原因分析 Listview item 缓存机制:为了使得性能更 ...

  3. PHP中json_encode后,在json字符串中依然显示中文的解决方案

    <?php header("Content-Type:text/html;charset=utf-8;"); $arr = array ('Version_code'=> ...

  4. vue中eslint报错的解决方案

    1,Newline required at end of file but not found. (eol-last) //文末需要一行 这个是报错: 这个是不报错的: 只需要在最后一行加上一空行即可 ...

  5. 在vue中选中某个标签,并且对其属性进行操作

    第一步:在标签中添加ref="111"属性 第二步:this.$refs.111.属性=""   此步骤是一111为标记选中了要操作的标签,通过点属性的方法,进 ...

  6. 当Vue中img的src是动态渲染时不显示问题

    最近遇见动态渲染img时,想起了当初刚开始写vue时,曾经遇见的一个小小坑. Vue中:img的src属性是动态渲染时不显示问题1.需求:展示用户头像,数据从后台获取,如果没有拿到则显示默认图片. 如 ...

  7. vue中使用vue-pdf插件显示pdf

    最近项目需求需要在vue中展示pdf,上网搜索了实现方法,找到vue-pdf这个插件非常好用,并且还有许多方法.属性能进行功能扩展. 一.安装 npm install --save vue-pdf 二 ...

  8. mvc 分部视图(Partial)显示登陆前后变化以及Shared文件夹在解决方案资源管理器中没有显示的问题

    刚开始我的解决方案资源管理器中没有显示Shared文件夹,但Shared文件夹在项目中是实际存在的,我搜了下好像没有类似的解答(可能是我搜索的关键词不够准确).后来自己看了下vs2012. 其实解决方 ...

  9. vue中el-upload上传多图片且携带参数,批量而不是一张一张的解决方案

    现在前端基本不是vue技术栈就是react技术栈. vue技术栈最常用的就是element-ui的ui框架了. 在项目中,我们经常会碰到这种需求:批量上传文件 element-ui 确实也为我们提供了 ...

随机推荐

  1. 洛谷P1192 台阶问题【记忆化搜索】

    题目:https://www.luogu.org/problemnew/show/P1192 题意: 给定n和k,一个人一次可以迈1~k步,问走n步有多少种方案. 思路: 本来傻乎乎上来就递归,显然会 ...

  2. [No0000C8]英特尔快速存储IRST要不要装

    IRST (英特尔快速存储技术)Intel Rapid Storage Technology(简称IRST)又称英特尔快速存储技术. Intel Rapid Start Technolog同样是简称( ...

  3. 区块链共识机制:POW、POS、DPOS、PBFT、POOL

    共识机制作为区块链的关键技术之一,在业务吞吐量.交易速度.不可篡改性.准入门槛等等方面发挥重要的作用. 区块链是去中心化的,没有中心记账节点,所以需要全网对账本达成共识.目前有POW.POS.DPOS ...

  4. RabbitMQ 分布式设置和高可用性讨论

    abbitMQ的集群主要有配置方式,分别是:本地局域网Cluster,federation,shovel. RabbitMQ Cluster主要是用于同一个网段内的局域网. federation和sh ...

  5. 无法跨越程序集边界使用程序集“DataCheck, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”中的类型“List<ILayer>”,因为该类型有一个为嵌入互操作类型的泛型类型参数

    主窗体: FrmDataInspect f2 = new FrmDataInspect(listMapControl1Lyr); f2.Show(); 弹出的窗体: 应该改为: gListMapLyr ...

  6. Isomorphism 同构

    小结: 1.两个有限维度的向量空间,在同一数域下,是同构的 等价于 它们维数相等. Isomorphism 同构 0.1.8 Isomorphism. If U and V are vector sp ...

  7. 2018/05/11 PHP 设计模式之 适配器模式

    什么是适配器模式? 简单来说,我想买一根充电线,我买一根安卓的?还是买一根苹果的? 我也不确定,因为我以可能会换手机,对于我的形式我也不确定. 所以,我要买一根可以同时适配 安卓/苹果 的线. 所谓适 ...

  8. pandas之DataFrame

    DataFrame 类型类似于数据库表结构的数据结构,其含有行索引和列索引,可以将DataFrame 想成是由相同索引的Series组成的Dict类型.在其底层是通过二维以及一维的数据块实现. 1,D ...

  9. ELKstack5.6.5

    ELKstack 安装: 一:环境准备: 1.给添加块磁盘50G,相当于模拟raid 2.分别给它们做本机的主机解析 [root@node01 ~ ]#cat  /etc/hosts 127.0.0. ...

  10. VSCode代码修改后跑起来没反应,打开本地文件,代码没变化

    两种解决办法: 首先:修改VSCode默认配置文件,点击左下角设置标志图 -> 设置,出来了设置相关的东西,搜索 files.autoSave 第一种:把"files.autoSave ...