当前位置: 首页 > news >正文

jsp的动态网站开发google浏览器官网

jsp的动态网站开发,google浏览器官网,做网站市场分析,wordpress链接修改密码目录 现象分析原因 浏览器中Js是单线程的,当然不可能出现线程安全问题。只是遇到的问题的现象与多线程的情况十分相似,导致对不了解Vue实现的我怀疑起了人生… 现象 项目中用到了element-plus中的加载组件,简单封装了一下,用来保…

目录

  • 现象
  • 分析
  • 原因

浏览器中Js是单线程的,当然不可能出现线程安全问题。只是遇到的问题的现象与多线程的情况十分相似,导致对不了解Vue实现的我怀疑起了人生…

现象

项目中用到了element-plus中的加载组件,简单封装了一下,用来保证只会出现一个加载框,大概是这样

import { ElLoading } from 'element-plus'let instance
let count = 0
export function startLoading() {if (count === 0) {// 临界区instance = ElLoading.service()}count++
}
export function stopLoading() {count--if (count === 0) {instance.close()}
}

使用的时候,意外的出现了多个实例,但是只保存了最后创建的实例,导致界面上有个loading无法关闭。
复现Demo

分析

打断点调试发现,到instance = ElLoading.service()之后没有继续往下count++而是再次去到if (count === 0),由于还没有++所以count还是0,进入if,重复创建了loading实例。
这个现象,乍一看,和有两条线程同时进入了startLoading的情况一模一样。不过我发现后面count++的值是没错的,所以把count++提到前面,改成这样,问题没有再复现。

export function startLoading() {count++if (count === 1) {instance = ElLoading.service()}
}

如果存在线程安全,那么count++如果不是原子操作的话,同样的问题还是会出现的。查了一圈资料,没有找到相关信息。
最终是在打断点的时候看了一眼调用堆栈,发现第二次的startLoading是在第一次的Loading组件mount的时候调用的。也就是说两次调用是串行的嵌套关系,而不是并行,直接松了一口气😅
调用堆栈截图

原因

问题的关键在于Vue的watch实现,第二次的startLoading是在watch中调用的。watch的数据变化事件会被Vue放到队列中,在mount组件时会先处理这个队列,所以在mount第一个Loading组件时,执行了第二个startLoading
关键方法是flushPreFlushCbs,具体之后再学习学习

http://www.15wanjia.com/news/37099.html

相关文章:

  • 建设本地网站长沙seo关键词排名优化
  • 网站专题怎么做呢应用商店下载安装
  • 营销型网站建设优化seo新站如何快速排名
  • 360建筑网的内容百度可以查到吗seo网络推广专员
  • 古城网站建设西安seo经理
  • 花桥网站建设网络营销10大平台
  • ps怎样做网站首页图专业百度seo排名优化
  • 网站营销推广培训seo排名优化方式方法
  • 公司招人去哪个网站营销qq
  • 新闻网站开发的目的和意义最好的免费建站网站
  • 网站开发设计大概多少费用深圳整站全网推广
  • 利用wordpress建站怎么上传网页软文有哪些推广渠道
  • 软件外包公司名单seo优化推广技巧
  • 企业为什么网站建设今日热点新闻事件
  • 微信小程序开发制作廊坊百度seo公司
  • 来个网站吧好人一生平安怎样做好销售和客户交流
  • 网站开发安全管理南京seo推广
  • 雅安交通建设集团网站怎么在网上推销产品
  • 网站服务理念弹窗广告最多的网站
  • 佛山公司网站建设浙江搜索引擎优化
  • .简述网站开发的流程热词搜索排行榜
  • 做网站常见程序新手怎样推销自己的产品
  • 做旅游网站的首页的图片长春百度关键词优化
  • 中国建设银行官网站企业银行福州整站优化
  • 网站上做商城可用同一域名软文营销方案
  • 阿里云网站访问不了怎么办大一网页设计作业成品免费
  • 自己做网站网页文件在哪里百度公司名称
  • 宁波网络推广优化湛江seo推广外包
  • 做网站做哪个好每日重大军事新闻
  • 公司网站建设如何做账店面怎么做位置定位