JS New Worker() 深度解析

news2024/12/23 22:59:58

JS New Worker() 深度解析


在这里插入图片描述

文章目录

    • 一、New Worker() 是什么及为什么出现
    • 二、JS中如何使用 New Worker()
      • 1. 创建 Worker 线程
      • 2. 向 Worker 发送消息
      • 3. 接收 Worker 的消息
      • 4. 监听错误和结束事件
      • 5. 终止 Worker
    • 三、Worker 包含哪些属性或方法 API
      • 1. 属性
      • 2. 方法
    • 四、扩展与高级技巧
      • 1. 使用多个 Worker
      • 2. 使用 SharedWorker
      • 3. 使用 Service Workers
      • 4. 传递复杂数据
      • 5. 错误处理
    • 五、优点与缺点
      • 优点
      • 缺点
    • 六、对应“八股文”或面试常问问题
      • 1. 问:什么是 Web Workers?
      • 2. 问:如何创建一个 Worker 线程?
      • 3. 问:如何向 Worker 发送消息和接收来自 Worker 的消息?
      • 4. 问:Worker 有哪些常见的事件处理器?
      • 5. 问:你可以在 Worker 中使用哪些 API?哪些 API 是不能在 Worker 中使用的?
    • 七、总结与展望
    • 八、完整使用示例

一、New Worker() 是什么及为什么出现

Worker 是 Web Workers 的一部分,它允许 Web 应用程序在后台线程中运行脚本,而不会干扰用户界面的操作。这意味着,即使执行复杂的计算或数据处理任务,也不会阻塞或冻结用户界面。New Worker() 构造函数就是用来创建一个新的 Worker 线程。

Web Workers 的出现是为了解决 JavaScript 单线程执行模型带来的问题。在传统的 JavaScript 执行模型中,所有任务都在同一个线程上执行,这会导致长时间运行的任务阻塞用户界面,影响用户体验。Web Workers 提供了一种在后台线程中执行脚本的方式,从而避免了这个问题。

二、JS中如何使用 New Worker()

1. 创建 Worker 线程

你可以通过传递一个要在新线程中执行的脚本的 URL 来创建一个 Worker 对象。

const worker = new Worker('worker.js');

2. 向 Worker 发送消息

创建 Worker 后,你可以使用 postMessage() 方法向其发送消息。

worker.postMessage('Hello Worker!');

3. 接收 Worker 的消息

要接收来自 Worker 的消息,你需要监听主线程上的 message 事件。

worker.onmessage = function(e) {
  console.log('Message from worker:', e.data);
};

4. 监听错误和结束事件

你还应该监听 errorterminate 事件来处理可能的错误和 Worker 线程的结束。

worker.onerror = function(error) {
  console.error('Worker error:', error);
};

worker.onterminate = function() {
  console.log('Worker terminated.');
};

5. 终止 Worker

如果你需要,可以随时终止 Worker 线程。

worker.terminate();

三、Worker 包含哪些属性或方法 API

1. 属性

  • onmessage: 消息到达时的事件处理器。
  • onerror: 出现错误时的事件处理器。
  • onterminate: Worker 结束时的事件处理器。

2. 方法

  • postMessage(data): 向 Worker 发送消息。
  • terminate(): 立即终止 Worker

四、扩展与高级技巧

1. 使用多个 Worker

你可以创建多个 Worker 来并行处理任务,从而进一步提高应用程序的性能。

2. 使用 SharedWorker

SharedWorker 可以在多个浏览器标签页、iframe 或甚至不同的浏览器窗口之间共享。

3. 使用 Service Workers

Service Worker 是一种特殊类型的 Worker,它运行在浏览器后台,可以控制网页与网络的交互,包括缓存、网络请求等。

4. 传递复杂数据

你可以通过 postMessage() 方法传递几乎任何类型的数据,包括对象、数组等,这些数据会被自动序列化和反序列化。

5. 错误处理

确保在 Worker 脚本和主线程中都添加适当的错误处理逻辑,以便在出现问题时能够优雅地恢复。

五、优点与缺点

优点

  1. 不会阻塞 UI 线程。
  2. 可以执行复杂或耗时的任务。
  3. 可以并行处理多个任务。

缺点

  1. Worker 之间不共享作用域,因此不能直接访问主线程上的变量或函数。
  2. 调试比较困难,因为 Worker 运行在单独的线程中。
  3. 某些 API(如 DOM)在 Worker 中不可用。

六、对应“八股文”或面试常问问题

1. 问:什么是 Web Workers?

:Web Workers 是 HTML5 提供的一种技术,它允许 Web 应用程序在后台线程中运行脚本,而不会干扰用户界面的操作。这样,即使执行复杂的计算或数据处理任务,也不会阻塞或冻结用户界面。

2. 问:如何创建一个 Worker 线程?

:要创建一个 Worker 线程,你可以使用 new Worker(url) 构造函数,其中 url 是要在新线程中执行的脚本文件的路径。创建后,你可以通过 postMessage() 方法向 Worker 发送消息,并通过监听 message 事件来接收来自 Worker 的消息。

3. 问:如何向 Worker 发送消息和接收来自 Worker 的消息?

:要向 Worker 发送消息,你可以使用 postMessage() 方法,并传递要发送的数据。要接收来自 Worker 的消息,你需要监听主线程上的 message 事件,并在事件处理函数中处理接收到的数据。

4. 问:Worker 有哪些常见的事件处理器?

:Worker 常见的事件处理器包括 onmessage(用于处理接收到的消息)、onerror(用于处理错误)和 onterminate(用于处理 Worker 线程的结束)。

5. 问:你可以在 Worker 中使用哪些 API?哪些 API 是不能在 Worker 中使用的?

:在 Worker 中,你可以使用大多数 JavaScript API,但有一些 API 是不能在 Worker 中使用的,比如与 DOM 相关的 API(因为 Worker 没有访问 DOM 的权限)。此外,一些全局对象(如 windowdocument)在 Worker 中也是不可用的。

七、总结与展望

Web Workers 提供了一种在后台线程中运行脚本的方式,而不会干扰用户界面的操作。这对于执行复杂或耗时的任务非常有用。虽然 Worker 有一些限制,但它们在提高 Web 应用程序性能和用户体验方面发挥着重要作用。随着 Web 技术的不断发展,我们期待看到更多关于 Web Workers 的新特性和改进。

八、完整使用示例

// 主线程代码
const worker = new Worker('worker.js');

worker.onmessage = function(e) {
  console.log('Message from worker:', e.data);
};

worker.onerror = function(error) {
  console.error('Worker error:', error);
};

worker.postMessage('Start working!');

// worker.js 代码
onmessage = function(e) {
  console.log('Message from main:', e.data);
  postMessage('Working...');
};

看到这里的小伙伴,欢迎点赞、评论,收藏!

如有前端相关疑问,博主会在第一时间解答,也同样欢迎添加博主好友,共同进步!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2076842.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

customRef 与 ref

ref() 我们已经很熟悉了,就是用来定义响应式数据的,其底层原理还是通过 Object.defineprotpty 中的 get 实现收集依赖( trackRefValue 函数收集),通过 set 实现分发依赖通知更新( triggerRefValue 函数分发 )。我们看看 ref 的源码就知道了 …

适合学生党用的充电宝有哪些?四款百元性价比充电宝推荐

在如今这个电子设备不离手的时代,充电宝成为了学生党们的必备好物。无论是在教室、图书馆学习,还是外出游玩,一款可靠的充电宝能够为手机、平板等设备随时补充电量,让你不再为电量焦虑而烦恼。今天,我们就为学生党们精…

AES对称加密算法

1. 简介 AES是一种对称加密算法, 它有3种类型: AES-128: 密钥为128位(16字节)的AES, 加密10轮AES-192: 密钥为192位(24字节)的AES, 加密12轮AES-256: 密钥为256位(32字节)的AES, 加密14轮 密钥长度越长, 加密的强度越大, 当然与此同时开销也越大。每种类型下都有几种操作模式…

【JavaEE】深入浅出 Spring AOP:概念、实现与原理解析

目录 Spring AOPAOP概述Spring AOP快速⼊⻔引⼊AOP依赖编写AOP程序 Spring AOP 详解Spring AOP核⼼概念切点(Pointcut)连接点(Join Point)通知(Advice)切⾯(Aspect) 通知类型PointCut切⾯优先级 Order切点表达式execution表达式annotation⾃定义注解 MyAspect切⾯类添加⾃定义注…

力扣第71题:简化路径 放弃栈模拟,选择数据流√(C++)

目录 题目 思路 解题过程 复杂度 Code 题目 给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 / 开头),请你将其转化为更加简洁的规范路径。 在 Unix 风格的文件系统中,一个点&#xff…

K8S持久化存储数据volumeMountsvolumes

环境: Ubuntu-1:192.168.114.110作为主 Ubuntu-2:192.168.114.120作为从1,node节点1 Ubuntu-3:192.168.114.130作为从2,node节点2 持久化volumeMounts pod里面:emptyDir和hostPath。存储在node,NFS...,Clo…

文本处理函数

1.文本的提取 left mid right 2.文本的查找与替换 replace,substitute 3.字符个数 len字符 lenb字节, office365好像没有此功能 4.数据的清理 clean , trim 5.找不同 exact

codetop标签动态规划大全C++讲解(上)!!动态规划刷穿地心!!学吐了家人们o(╥﹏╥)o

主要供自己回顾学习,会持续更新,题源codetop动态规划近半年 1.零钱兑换2.零钱兑换II3.面试题08.11.硬币4.单词拆分5.最长递增子序列6.最长递增子序列的个数7.得到山形数组的最少删除次数8.最长公共子序列9.最长重复子数组10.最长等差数列11.最大子数组和…

智能优化算法-海鸥优化算法(SOA)(附源码)

目录 1.内容介绍 2.部分代码 3.实验结果 4.内容获取 1.内容介绍: 海鸥优化算法 (Seagull Optimization Algorithm, SOA) 是一种基于群体智能的元启发式优化算法,它模拟了海鸥的觅食、飞行和社会交互行为,用于解决复杂的优化问题。 SOA的工…

wxpython Scintilla styledtextctrl滚动条拖到头文本内容还有很多的问题

wxpython Scintilla styledtextctrl滚动条拖到头文本内容还有很多的问题 使用wxpython Scintilla styledtextctrl,滚动条不自动更新 滚动条拖到头文本内容还有很多,如下: 以下是拖到最后的状态: 明显看出下图的滚动条的格子比…

书生.浦江大模型实战训练营——(十一)LMDeploy 量化部署进阶实践

最近在学习书生.浦江大模型实战训练营,所有课程都免费,以关卡的形式学习,也比较有意思,提供免费的算力实战,真的很不错(无广)!欢迎大家一起学习,打开LLM探索大门&#xf…

超声波清洗机哪个品牌好?专业测评师推荐四款高质量眼镜清洗机

近年来,越来越多的用户在使用超声波清洗机清洗小物件,因为超声波清洗机不仅能清洗眼镜,还能清洗各种各样的小饰品、餐具、茶具、剃须刀、金属制品等,有一个智能超声波清洗机在家里,对于生活质感的提升还是挺大的&#…

第一个NIO开发演示

文章目录 Channel简介Buffer简介第一个NIO程序分析 上一篇文章 介绍了传统网络编程在处理高并发和大规模应用时通常面临性能瓶颈和资源管理问题,而 NIO 通过非阻塞 I/O 和选择器机制提供了更高效的解决方案。虽然 NIO 的 API 更复杂,但在高负载和高性能需…

先从路径优化开始学习FastPlanner之B样条曲线平滑路径(一):从拉格朗日插值到B样条曲线

参考B站视频学习 注:我会列出学习他人的博客,但我不涉及具体推导,原理讲解,旨在于理解必须概念后写代码出效果。 给若干点如何获得一条平滑的曲线? 两个方法插值、拟合 插值要经过给定点,拟合不用经过。 经…

Hostease的Windows虚拟主机如何设置错误页面

404错误设置主要用于定义当访问网站上不存在的页面时服务器应该如何响应。通常,404错误表示请求的页面或资源不存在。在Plesk面板中,你可以通过404错误设置来配置服务器对这种情况的处理方式。下面我就介绍如何在Hostease的Windows虚拟主机中设置404错误…

探索数据结构:图(一)之邻接矩阵与邻接表

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:数据结构与算法 贝蒂的主页:Betty’s blog 1. 图的定义 **图(Graph)**是数学和计算机科学中…

Mybatis-plus 创建自定义 FreeMarker 模板详细教程

FreeMarker 自定义模板官方步骤 网址:https://baomidou.com/reference/new-code-generator-configuration/#%E6%A8%A1%E6%9D%BF%E9%85%8D%E7%BD%AE-templateconfig (页面往最下面拉为自定义模板相关内容) 创建自定义FreeMarker 模板及使用…

案例分享—优秀ui设计作品赏析

多浏览国外优秀UI设计作品,深入分析其设计元素、色彩搭配、布局结构和交互方式,以理解其背后的设计理念和趋势。 在理解的基础上,尝试将国外设计风格中的精髓融入自己的设计中,同时结合国内用户的审美和使用习惯,进行创…

趣味算法------试用 6 和 9 组成的最大数字

目录 ​编辑 题目描述 解题思路 具体代码 总结 题目描述 给你一个仅由数字 6 和 9 组成的正整数 num。 你最多只能翻转一位数字,将 6 变成 9,或者把 9 变成 6 。 请返回你可以得到的最大数字。 输入格式 一个整数 输出格式 一个整数 输入输出…

【机器学习】决策树------迅速了其基本思想,Sklearn的决策树API及构建决策树的步骤!!!

目录 🍔 案例剖析 🍔 通过sklearn实现决策树分类并进一步认识决策树 🍔 基于规则构建决策树 🍔 构建决策树的三个步骤 🍔 小结 学习目标 🍀 了解决策树算法的基本思想 🍀 了解Sklearn的决策…