使用 Web Workers 作为setInterval的替代方案
使用 Web Workers 作为setInterval的替代方案
在 Vue 项目中,为了避免 setInterval 在标签页非激活状态下的不准确问题,我们可以使用 Web Workers 作为一个替代方案
Web Worker 介绍:
Web Workers:
浏览器后台为网页运行的一个小助手,它可以在不干扰网页当前页面显示和交互的情况下,独立地执行一些任务
Web Workers的运行是独立于主线程的,这意味着即使它们在后台进行重量级计算,也不会影响到你滚动网页、点击按钮等操作的流畅性理解为浏览器中的一个轻量级的
“后台进程”不能直接访问DOM(文档对象模型),这意味着你不能在 Worker 里直接修改网页的内容;
可以通过发送消息的方式与主线程通信,比如让 Worker 处理完任务后,将结果发送回主线程,然后由主线程来更新网页内容
步骤 1: 创建 Web Worker 文件
首先,你需要创建一个 Web Worker 脚本文件。命名为 timerWorker.js,并放置以下代码:
// timerWorker.js
let intervalId = null;self.addEventListener('message', e => {const { type, interval } = e.data;// 监听消息类型为'start'(你自定义的类型)if (type === 'start') {if (intervalId !== null) {clearInterval(intervalId);}intervalId = setInterval(() => {// 建立setInterval计时器,向主线程发送消息self.postMessage('tick');}, interval);} else if (type === 'stop') {if (intervalId !== null) {clearInterval(intervalId);intervalId = null;}}
});
步骤 2: 在 Vue 组件中使用 Web Worker
在你的 Vue 组件中,你可以如下使用 Web Worker:
<template><div><p>计时器 ticks: {{ ticks }}</p></div>
</template><script>
export default {data() {return {ticks: 0,worker: null,};},mounted() {if (window.Worker) {this.worker = new Worker(process.env.BASE_URL + 'timerWorker.js');// 设置接收到/timerWorker.js消息时的执行函数;this.worker.onmessage = this.cbDo;// 发送start类型消息this.worker.postMessage({ type: 'start', interval: 1000 });}else{// 考虑添加退回方案alert('浏览器不支持');}},beforeDestroy() {if (this.worker) {this.worker.terminate();}},methods: {cbDo(msg) {// 计时到,你要做的事},},
};
</script>
注意事项
- ✅ 这里
process.env.BASE_URL是Vue CLI提供的一个环境变量,它会根据你的项目配置返回正确的基路径;确保即使你的应用部署在子路径下,引用的路径也是正确的 - ✅ 确保
Web Worker文件 (timerWorker.js) 的路径正确,如果使用Vue CLI,可以将它放在public目录下。 - ✅ 在
Web Worker和主线程之间使用消息传递来启动、停止定时器,以及接收定时器的“tick”消息。 - ✅ 使用这种方法,即使在浏览器标签页处于非激活状态时,定时器也能保持较高的准确性,避免了传统定时器
setInterval的问题。
可能遇到的问题
- 🔴
timeworker.js文件报错Uncaught SyntaxError: Unexpected token '<':考虑timerWorker.js路径方面;
相关文章:
使用 Web Workers 作为setInterval的替代方案
使用 Web Workers 作为setInterval的替代方案 在 Vue 项目中,为了避免 setInterval 在标签页非激活状态下的不准确问题,我们可以使用 Web Workers 作为一个替代方案 Web Worker 介绍: Web Workers : 浏览器后台为网页运行的一个小助手&…...
python实现将日期文本化
环境:python3.8.10 需要:有些时候,需要在一段文本的后面,添加上日期,尤其是文本重复的情况下,添加上每天的日期更为重要。 代码实现: import datetimetodaydatetime.date.today() date_textto…...
react ant design 通过函数弹出 modal窗口
在React Ant Design中,可以通过调用Modal组件的方法来动态弹出和关闭Modal窗口。具体步骤如下: 1、首先,在组件中引入Modal组件: import { Modal } from antd;2、在组件中定义一个函数来弹出Modal窗口: const showM…...
力扣刷题Days33-209. 长度最小的子数组(js)
目录 1,题目-滑动窗口 2,代码 滑动窗口 3,学习与总结 1,题目-滑动窗口 给定一个含有 n 个正整数的数组和一个正整数 target 。找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1,…...
面对DDOS攻击,有哪些解决办法
随着互联网带宽的持续增长以及DDOS黑客技术的发展,DDOS拒绝服务攻击的实施变得愈发容易。商业竞争、打击报复、网络敲诈等多种因素,各行各业的用户都曾受到DDOS攻击的威胁。 一旦遭受到DDOS攻击,随之而来的就是业务宕机,用户无法…...
C++ GDAL提取多时相遥感影像中像素随时间变化的数值数组
本文介绍基于C语言GDAL库,批量读取大量栅格遥感影像文件,并生成各像元数值的时间序列数组的方法。 首先,我们来明确一下本文所需实现的需求。现在有一个文件夹,其中包含了很多不同格式的文件,如下图所示。 其中&#x…...
免费-华为od-C卷-javascript-动态规划-贪心歌手.js
动态规划-贪心歌手 还有很多其他题,链接是github, 进去可以查看对应文件夹就行...
elementui 实现一个固定位置的Pagination(分页)组件
系列文章目录 一、elementui 导航菜单栏和Breadcrumb 面包屑关联 二、elementui 左侧导航菜单栏与main区域联动 三、elementui 中设置图片的高度并支持PC和手机自适应 四、 elementui 实现一个固定位置的Pagination(分页)组件 文章目录 系列文章目录…...
紧急备考全攻略,如何短期通过PMP考试?
今年身边有很多同事朋友都要考PMP,而我属于这些人里”第一个吃螃蟹“的人,一次拿下5A,下面分享一下我自己备考PMP的经验。 我是根据自己的学习计划复习的,不能说这些方法适合所有人,但对备考的伙伴们来说,…...
python开发poc,fofa爬虫批量化扫洞
学习使用python做到批量化的漏洞脚本 1.通过fofa搜索结果来采集脚本 2.批量化扫描漏洞 ---glassfish存在任意文件读取在默认48484端口,漏洞验证的poc为: "glassfish" && port"4848" && country"CN" http://loca…...
适用于 Windows 10 的 10 大免费数据恢复软件
数据丢失可能是一场噩梦,尤其是在涉及重要文件和文档时。无论是由于意外删除、系统崩溃还是病毒攻击,找到适合 Windows 10 的文件夹恢复软件都可以在恢复丢失的数据方面发挥重要作用。在本指南中,我们将探索适用于 Windows 10 用户的 10 大免…...
zabbix企业级监控平台
zabbix部署 安装源 重新创建纯净环境,利用base克隆一台虚拟机server1 给server1做快照,方便下次实验恢复使用 进入zabbix官网https://www.zabbix.com rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm …...
如何关闭WordPress的自动更新功能
Wordpress为什么自动更新 WordPress自动更新是为了提供更好的安全性和稳定性。 安全性:WordPress是一个广泛使用的内容管理系统,因此成为恶意攻击的目标。WordPress的自动更新功能确保你的网站及时获得最新的安全补丁和修复程序,以保护你的网…...
【分析 GClog 的吞吐量和停顿时间、heapdump 内存泄漏分析】
文章目录 🔊博主介绍🥤本文内容GClog分析以优化吞吐量和停顿时间步骤1: 收集GClog步骤2: 分析GClog步骤3: 优化建议步骤4: 实施优化 Heapdump内存泄漏分析步骤1: 获取Heapdump步骤2: 分析Heapdump步骤3: 定位泄漏对象步骤4: 分析泄漏原因步骤5: 修复泄漏…...
[STL-list]介绍、与vector的对比、模拟实现的迭代器问题
一、list使用介绍 list的底层是带头双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素。与其他的序列式容器相比(array,vector,deque),list通常在任意位置进行…...
代码随想录-035期-算法训练营【博客笔记汇总表】
ヾ(◍∇◍)ノ゙加油~ 目录 00、说明 01、刷题网址 02、每日打卡任务 03、博客打卡笔记 01、数组 02、链表 03、哈希表 04、字符串 05、双指针法 06、栈与队列 07、二叉树 08、回溯算法 09、贪心算法 10、动态规划 11、单调栈 12、图论 04…...
postgresql数据库|数据整合的好工具--Oracle-fdw的部署和使用
概述 Oracle_fdw 是一种postgresql外部表插件,可以读取到Oracle上面的数据。是一种非常方便且常见的pg与Oracle的同步数据的方法 Oracle_fdw 适用场景: Oracle_fdw 是一个开源的 Foreign Data Wrapper (FDW),主要用于在 PostgreSQL 数据库中…...
让php开发更优雅-Laravel篇
前言 随着开发经验的增加,也伴随团队开发的积累,规范开发显得越来越重要,本文给大家提供一些laravel开发的进阶思路和经验,让大家开发更加统一规范,代码看起来更加优雅。 1.更多使用第三方库。团队开发的时候…...
自动化测试之httprunner框架hook函数实操
本篇介绍httprunner中hook函数的使用,以及通过编程能力实现建设自动化测试更全面的场景覆盖 前置: 互联网时代让我们更快的学习到什么是Httprunner 正文: 经过上文了解到这个框架怎么使用之后,我们开始来探讨一下我们为什么要用…...
物联网实战--入门篇之(七)嵌入式-MQTT
目录 一、MQTT简介 二、MQTT使用方法 三、MQTT驱动设计 四、代码解析 五、使用过程 六、总结 一、MQTT简介 MQTT因为其轻量、高效和稳定的特点,特别适合作为物联网系统的数据传输协议,已经成为物联网事实上的通信标准了。关于协议的具体内容看看这…...
用Python搞定常微分方程:从显式RK4到隐式IRK6,一个类全搞定(附完整代码)
用Python搞定常微分方程:从显式RK4到隐式IRK6,一个类全搞定(附完整代码) 在工程计算和科学研究中,常微分方程(ODE)的数值求解是一个无法回避的问题。无论是模拟电路中的电流变化,还是…...
RobotStudio 仿真软件学习分享05——smart组件创建动态输送链、动态夹具与仿真运行
在工业机器人仿真工作站里,Smart 组件是实现无代码动态逻辑、自动输送、自动夹持、信号交互的核心工具。本次学习我们将从零搭建一套自动上料输送链 智能真空夹具 机器人码垛的完整仿真系统,把 “产品自动生成→输送→到位检测→机器人抓取→搬运码垛→…...
别再手动改防火墙了!用这条组策略,一键修复AD域强制更新时的RPC报错
自动化运维实战:用组策略统一管理AD域防火墙规则 在混合Windows环境的IT运维中,手动配置每台终端设备的防火墙规则无异于一场噩梦。想象一下,当您面对数百台运行不同Windows版本的计算机时,每次组策略更新都因为防火墙拦截RPC通信…...
基于eNSP的园区网络高可用与安全隔离综合实验
1. 实验背景与核心价值 园区网络作为企业数字化转型的基础设施,其稳定性和安全性直接关系到日常运营效率。记得去年参与某金融机构网络改造项目时,他们的核心业务系统因为单点故障导致全网瘫痪4小时,直接损失超过百万。这个案例让我深刻认识到…...
构建高可用代理池:开源工具agentpull的架构解析与实战部署
1. 项目概述:一个轻量级、可编程的代理拉取工具最近在折腾一些自动化任务和分布式爬虫时,经常遇到一个头疼的问题:如何高效、稳定地管理海量的代理IP资源。无论是数据采集、社交媒体运营还是安全测试,一个可靠的代理池都是基础设施…...
Uncle小说阅读器:桌面级智能小说聚合与个性化阅读方案
Uncle小说阅读器:桌面级智能小说聚合与个性化阅读方案 【免费下载链接】uncle-novel 📖 Uncle小说,PC版,一个全网小说下载器及阅读器,目录解析与书源结合,支持有声小说与文本小说,可下载mobi、e…...
别再只盯着效率了!DCDC降压芯片选型,这5个‘隐形’参数才是关键
别再只盯着效率了!DCDC降压芯片选型,这5个‘隐形’参数才是关键 在电源设计领域,工程师们往往过于关注DCDC降压芯片的效率、输入输出电压范围等基础参数,却忽略了那些真正影响系统长期稳定性和用户体验的"隐形"特性。这…...
Scroll Reverser深度解析:macOS事件拦截与独立滚动控制的高效实现
Scroll Reverser深度解析:macOS事件拦截与独立滚动控制的高效实现 【免费下载链接】Scroll-Reverser Per-device scrolling prefs on macOS. 项目地址: https://gitcode.com/gh_mirrors/sc/Scroll-Reverser Scroll Reverser是一款专为macOS设计的开源工具&am…...
不只是安装:用MATLAB+RTL-SDR硬件支持包快速上手你的第一个无线信号接收项目
不只是安装:用MATLABRTL-SDR硬件支持包快速上手你的第一个无线信号接收项目 当你第一次将RTL-SDR设备插入电脑,安装完MATLAB硬件支持包后,那种既兴奋又迷茫的感觉可能还记忆犹新。硬件已经就绪,软件也已安装,但接下来该…...
生物信息学新手必看:用K-means和WGCNA分析转录组数据的保姆级流程(附R代码)
生物信息学实战:从K-means到WGCNA的转录组分析全流程指南 第一次接触转录组数据分析时,我盯着满屏的基因表达矩阵完全无从下手。那些论文里看似流畅的分析流程,在实际操作时却处处是坑——数据格式报错、参数设置不合理、结果解读模糊...这正…...
