视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
H5的多线程如何实现WebWorker
2020-11-27 15:27:29 责编:小采
文档


很多人问过我,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页面中,使用 <script>

标签加载外部的JS文件,而<script>标签还支持 跨域 加载JS。

在Web Worker中要注意!

Worker实例化的时候必须传入一个脚本的URL,而这个URL必须是在本域下,否则会报跨域错误! var worker = new Worker('https://localhost/worker.js');

但可以在worker.js中通过importScripts方法引入任何域下的脚本,如同HTML中的<script>标签一样。下面是合法的使用方法:

importScripts(); /* imports nothing */ importScripts(‘foo.js’); /* imports just “foo.js” */ importScripts(‘foo.js’, ‘bar.js’); /* imports two scripts */ importScripts(‘//example.com/hello.js’); /* You can import scripts from other origins */
可以利用这里的importScripts方法解决资源预加载的问题(浏览器预先加载资源,而不会对资源进行解析和执行),道理也很简单。
Scripts may be downloaded in any order, but will be executed in the order in which you pass the filenames into importScripts() . This is done synchronously; importScripts() does not return until all the scripts have been loaded and executed.
</script>

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

相关阅读:

html5中的DOM编程的实现步骤

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

用H5做有特效的下拉框

下载本文
显示全文
专题