登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
业界区
›
业界
›
Web前端入门第 86 问:JavaScript 中的 Web Worker 为什 ...
Web前端入门第 86 问:JavaScript 中的 Web Worker 为什么能提升代码性能?
[ 复制链接 ]
章绮云
2025-9-28 18:44:52
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
最初的 JS 执行代码都是一条线执行到底,当遇到比较耗时的操作时,比如大数组循环运算,就会导致页面卡着,就像假死一样。就像一个人在厨房烧菜一样,需要依次完成切菜、炒菜、装盘这些步骤,此过程中没办法同时做其他事情,必须按顺序执行每一个步骤。
Web Worker 赋予了 JS 分配任务的能力,在遇到复杂的计算型任务时,比如 canvas 图形图像处理(添加滤镜、矩阵变换等),此类不依赖 DOM 操作的计算型任务都可以交由 Web Worker 来处理,这样不会阻塞主线程的任务调度,从而提升前端的代码运行速度。
任务时序图
模拟耗时任务
看如下代码,使用一个超大的 for 循环,模拟 JS 中的耗时任务,让代码执行时主线程卡顿,还原假死现象:
<button id="start"><button id="start">开始复杂任务</button></button>
复制代码
执行结果:
可以看到点击
<button id="start"><button id="start">开始复杂任务</button></button>
按钮时,在计时器的第 4 秒主线程卡主了将近 4 秒,然后再恢复运行,这就是单线程中的 JS 耗时任务导致的页面假死现象。
使用 Web Worker 解决耗时问题
看了上面的耗时任务导致页面假死,再使用 Web Worker 来重写一下上面代码:
main.html
<button id="start"><button id="start">开始复杂任务</button></button>
复制代码
worker.js
// worker.js
self.onmessage = event => {
let n = 0
let max = event.data
for (let i = 0; i < max; i++) {
n += i
}
postMessage(n)
}
复制代码
执行结果:
可以看到虽然任务耗时长短差不多,但是主线程在点击按钮之后并没有进入假死状态,定时器还是在顺利执行,所以 Web Worker 中运行的复杂任务并不会影响主线程的任务调度。
Web Worker 限制
在子线程中运行的代码,无法直接操作 DOM,无法访问 window/document 对象,也无法使用 localStorage 等,如果使用这些 API,代码将会报错:
for 循环优化
注意上述代码中的 max 变量,为什么需要一个变量来保存 event.data 值?而不是直接使用 event.data 循环?将 worker.js 改造一下,看看不同使用方式的任务耗时:
// worker.js
self.onmessage = event => {
console.time('max 循环耗时')
let n = 0
let max = event.data
for (let i = 0; i < max; i++) {
n += i
}
console.timeEnd('max 循环耗时')
console.time('Object 循环耗时')
let m = 0
for (let i = 0; i < event.data; i++) {
m += i
}
console.timeEnd('Object 循环耗时')
postMessage(n)
}
复制代码
main.html
// main.html
(() => {
const worker = new Worker('./worker.js')
document.getElementById('start').addEventListener('click', () => {
worker.postMessage(100000000)
})
})();
复制代码
执行结果:
可以明显看到,性能耗时相差将近 6 倍,这数字会随着对象属性越多,耗时越长!!
所以在循环中应当尽量避免读取对象属性,尽可能使用变量来做循环条件!!
写在最后
可以使用 Web Worker 同时启用多个工作线程,只是在任务调度的时候,需要注意响应结果的先后顺序是否对主线程的运行有影响。
一些复杂的计算任务(比如视频转码,图片压缩,图片处理等),都丢给子线程处理吧,咱们前端也可以玩玩多线程~~
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
Web
前端
门第
JavaScript
中的
相关帖子
一些有用的javascript函数
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
FreeSWITCH 1.10.12 在 Debian 最新版本系统中的编译指南
FreeSWITCH 1.10.12 在 Debian 最新版本系统中的编译指南
前端工程化 - 良好的feature-based-目录结构与具体示例
Java 中的 封装、继承、多态
MindIE 踩坑日记和一个web小工具
前端实现速度线
为什么 SVG 能在现代前端中胜出?
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
代码
一些有用的javascript函数
12
986
司寇涵涵
2026-02-07
业界
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
2
22
少琼
2026-02-09
业界
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
0
7
厂潺
2026-02-09
业界
FreeSWITCH 1.10.12 在 Debian 最新版本系统中的编译指南
1
7
叟减
2026-02-11
业界
FreeSWITCH 1.10.12 在 Debian 最新版本系统中的编译指南
1
6
仁夹篇
2026-02-11
代码
前端工程化 - 良好的feature-based-目录结构与具体示例
0
15
胥望雅
2026-02-11
安全
Java 中的 封装、继承、多态
3
7
判涔
2026-02-12
业界
MindIE 踩坑日记和一个web小工具
0
135
志灿隐
2026-02-13
代码
前端实现速度线
1
871
寨亳
2026-02-13
安全
为什么 SVG 能在现代前端中胜出?
0
385
跟尴
2026-02-14
回复
(24)
崔和美
2025-11-8 00:54:56
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢分享,下载保存了,貌似很强大
简千叶
2025-12-25 04:17:00
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
这个有用。
全阳霁
2026-1-14 06:01:41
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
用心讨论,共获提升!
赖琳芳
2026-1-20 10:01:35
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
谢谢楼主提供!
吁寂
2026-1-22 07:44:52
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
热心回复!
薯羞
2026-1-23 05:22:52
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
喜欢鼓捣这些软件,现在用得少,谢谢分享!
戈森莉
2026-1-24 05:30:15
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢,下载保存了
全叶农
2026-1-25 10:20:31
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
热心回复!
施婉秀
2026-1-27 02:02:34
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
嶝扁
2026-1-28 06:19:23
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
晚能
2026-1-30 05:13:11
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
前排留名,哈哈哈
窟聿湎
2026-1-30 06:05:18
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢发布原创作品,程序园因你更精彩
老僻贞
2026-2-7 07:35:41
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
前排留名,哈哈哈
皮仪芳
2026-2-7 08:00:38
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
分享、互助 让互联网精神温暖你我
瞪皱炕
2026-2-8 09:38:47
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
懂技术并乐意极积无私分享的人越来越少。珍惜
寥唏
2026-2-8 12:46:43
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
收藏一下 不知道什么时候能用到
赐度虻
2026-2-9 01:11:29
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享,学习下。
挫莉虻
2026-2-9 13:09:58
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢发布原创作品,程序园因你更精彩
蔡如风
2026-2-9 16:46:03
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
这个有用。
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
签约作者
程序园优秀签约作者
发帖
章绮云
2026-2-9 16:46:03
关注
0
粉丝关注
18
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991124
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
宋子
9898
6
韶又彤
9918
7
闰咄阅
9993
8
刎唇
9995
9
蓬森莉
9883
10
遗憩
10006
查看更多
今日好文热榜
317
OpenClaw多Agent协作踩坑实录:从翻车到跑
712
【节点】[MainLightShadow节点]原理解析与
630
模拟退火算法
899
Claude Code 的 Skills 可以在 Trae IDE 中
254
付费 AI 用户和免费用户之间,究竟差了什么
699
手把手教你使用vscode开发stm32!
1003
“老东西,你懦弱了”——关于Vibe Coding
926
告别Hyprland/Niri键鼠共享难题:Pynergy
752
解惑|公司员工健身房需要哪些器材?上海皓
518
凸优化数学基础笔记(六):凸集、凸函数与
389
SeeDance2.0提示词之跳舞女孩
11
SeeDance2.0提示词之跳舞女孩
683
国内零门槛首个免费 开源 7×24小时帮
572
[拆解LangChain执行引擎]非常规Pending Wri
69
AI开发-python-milvus向量数据库(2-8 -mil
80
[LKD/Linux 内核] 关于对 current_thread_i
9
[LKD/Linux 内核] 关于对 current_thread_i
7
[LKD/Linux 内核] 关于对 current_thread_i
7
9、PipedInputStream和PipedOutputStream的