热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

H5的多线程如何实现WebWorker

很多人问过我,H5的多线程如何实现WebWorker的?当我们说到这个问题的时候首先你需要知道,什么是WebWorker,那么今天就来给大家解答下这个问


很多人问过我,H5的多线程如何实现Web Worker的?当我们说到这个问题的时候首先你需要知道,什么是Web Worker,那么今天就来给大家解答下这个问题。

将Javascript代码交给Web Worker在后台执行时,页面就可以在Javascript运行期间依然可以响应用户操作,以防止出现页面卡死。用户可以创建多个Worker线程,这样就可以在前台做一些小规模分布式计算之类的工作。

分布式计算是一种计算方法,和集中式计算是相对的。随着计算基数的发展,有些应用需要非常巨大的计算能力才能完成,如果采用集中式计算,需要耗费相当长的时间来完成。分布式计算将该应用分解成许多小的部分,分配给多台计算机进行处理。这样可以节约整体计算时间,大大提高计算效率。

而我上面所说的小规模分布式计算是对CPU多核的高效利用。

线程中不能做的事情:

Web Worker无法访问DOM节点 不能共享DOM是正常的,否则这边在操作DOM,Worker那边也在操作DOM,甚至把DOM删除了,这不是冲突了嘛? Web Worker无法访问全局变量或是全局函数 Web Worker无法调用alert()或者confirm之类的函数 Web Worker无法访问window、document之类的浏览器全局变量

线程中能做的事情: 

能使用setTimeout()、clearTimeout()、setInterval()、clearInterval()等函数 能使用navigator对象 能使用XMLHttpRequest来发送请求 能使用Web Storage 能使用self获取本线程的作用域

Web Worker可分为两种类型:专用线程(dedicated web worker),共享线程(shared web worker)。专用线程只能被创建它的页面访问,随当前页面的关闭而结束;而共享线程可以被多个页面访问,只有当所有关联的页面都关闭的时候才会结束。相对专用线程,共享线程稍微复杂些。

检测浏览器对Web Worker的支

if(typeof(Worker)!=="undefined") {
// Yes! Web worker support!
} else {
// Sorry! No Web Worker support..
}

创建Web Worker对象及文件:

下面估计是最简单的入门级别的JS多线程Demo:

这里写图片描述

创建线程

var worker = new Worker(url);//url为需要在线程中执行的Javascript文件名及对应的路径

线程通信

在主线程与子线程间进行通信,使用的是线程对象的postMessage和onmessage方法。不管是谁向谁发送数据,发送方使用的都是postMessage方法,接收方都是使用的onmessage方法接收数据。postMessage和onmessage都只有一个参数,假定onmessage的参数为event,则通过event.data获取收到的数据。

销毁线程

在线程外部,使用线程实例的terminate方法销毁线程 在线程内部,使用close方法,线程自己销毁自己

处理错误

当线程发生错误的时候,它的onerror事件回调会被调用。

var worker = new Worker("test.js");
worker.Onerror= function(event){
console.log("load web worker error." + event);
}

发送JSON数据

复杂的数据就用JSON传送吧!

Web Worker中使用importScripts加载外部JS

在HTML页面中,使用


相信看了这些案例你已经掌握了方法,更多精彩请关注其它相关文章!

相关阅读:

html5中的DOM编程的实现步骤

用h5做出微信的支付过程的实现步骤

用H5做有特效的下拉框

以上就是H5的多线程如何实现Web Worker的详细内容,更多请关注其它相关文章!



推荐阅读
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • ImmutableX Poised to Pioneer Web3 Gaming Revolution
    ImmutableX is set to spearhead the evolution of Web3 gaming, with its innovative technologies and strategic partnerships driving significant advancements in the industry. ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 配置Windows操作系统以确保DAW(数字音频工作站)硬件和软件的高效运行可能是一个复杂且令人沮丧的过程。本文提供了一系列专业建议,帮助你优化Windows系统,确保录音和音频处理的流畅性。 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 如何高效创建和使用字体图标
    在Web和移动开发中,为什么选择字体图标?主要原因是其卓越的性能,可以显著减少HTTP请求并优化页面加载速度。本文详细介绍了从设计到应用的字体图标制作流程,并提供了专业建议。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
author-avatar
dingzhi521
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有