Web Worker

 

Internet Explorer 10 和使用 JavaScript 的 Windows 应用商店应用引入了对 Web Worker 的支持。Web Worker API 定义了一种在后台运行脚本的方法。 Web Worker 是在万维网联合会 (W3C) 的 Web Worker 规范中指定的。

从传统意义上来说,浏览器是单线程的,它们会强制应用程序中的所有脚本一起在单个 UI 线程中运行。虽然你可以通过使用文档对象模型 (DOM) 事件和setTimeout API 造成一种多个任务同时在运行的假象,但只需一个计算密集型任务就会使用户体验急转直下。

Web Worker API 为 Web 应用程序的创作人员提供了一种方法,用于生成与主页并行运行的后台脚本。你可以一次生成多个线程以用于长时间运行的任务。新的 worker 对象需要一个 .js 文件,该文件通过一个发给服务器的异步请求包含在内。

 
  1. var myWorker = new Worker('worker.js');

往来于 worker 线程的所有通信都通过消息进行管理。主机 worker 和 worker 脚本可以通过 postMessage 发送消息并使用 onmessage 事件侦听响应。消息的内容作为事件的数据属性进行发送。

下面的示例创建一个 worker 线程并侦听消息。

 
  1. var hello = new Worker('hello.js');
  2. hello.onmessage = function(e) {
  3. alert(e.data);
  4. };

worker 线程发送要显示的消息。

 
  1. postMessage('Hello world!');

与 Web Worker 进行双向通信

要建立双向通信,主页和 worker 线程都要侦听 onmessage 事件。在以下示例中,Worker 线程在指定的延迟后返回消息。

首先,该脚本创建 worker 线程。

 
  1. var echo = new Worker('echo.js');
  2. echo.onmessage = function(e) {
  3. alert(e.data);
  4. }

消息文本和超时值在表单中进行指定。当用户单击提交按钮时,脚本会将两条信息以 JavaScript 对象文本的形式传递给 worker。为了防止页面在新的 HTTP 请求中提交表单值,事件处理程序还对事件对象调用 preventDefault。注:你不能将对 DOM 对象的引用发送给 worker 线程。Web Worker 并非可以访问所有数据。只允许访问 JavaScript 基元(例如 Object 或 String 值)。

 
  1. <script>
  2. window.onload = function() {
  3. var echoForm = document.getElementById('echoForm');
  4. echoForm.addEventListener('submit', function(e) {
  5. echo.postMessage({
  6. message : e.target.message.value,
  7. timeout : e.target.timeout.value
  8. });
  9. e.preventDefault();
  10. }, false);
  11. }
  12. </script>
  13. <form id="echoForm">
  14. <p>Echo the following message after a delay.</p>
  15. <input type="text" name="message" value="Input message here."/><br/>
  16. <input type="number" name="timeout" max="10" value="2"/> seconds.<br/>
  17. <button type="submit">Send Message</button>
  18. </form>

最后,worker 侦听消息,并在指定的超时间隔之后将其返回。

 
  1. onmessage = function(e)
  2. {
  3. setTimeout(function()
  4. {
  5. postMessage(e.data.message);
  6. },
  7. e.data.timeout * 1000);
  8. }

在 Internet Explorer 10 和使用 JavaScript 的 Windows 应用商店应用中,Web Worker API 支持以下方法。

方法 描述

void close()

终止 worker 线程。

void importScripts(inDOMString... urls);

导入其他 JavaScript 文件的逗号分隔列表。

void postMessage(在任何数据中);

从 worker 线程发送消息或发送消息到 worker 线程。

Internet Explorer 10 和使用 JavaScript 的 Windows 应用商店应用支持以下 Web Worker API 属性:

属性 类型 描述
location WorkerLocation 代表绝对 URL,包括protocolhostporthostnamepathnamesearch 和 hash 组件。
navigator WorkerNavigator 代表用户代理客户端的标识和 onLine 状态。
self WorkerGlobalScope Worker 范围,包括 WorkerLocation 和 WorkerNavigator 对象。

Internet Explorer 10 和使用 JavaScript 的 Windows 应用商店应用支持以下 Web Worker API 事件:

事件 描述

onerror

出现运行时错误。

onmessage

接收到消息数据。

WindowTimers

Web Worker API 还支持更新的 HTML5 WindowTimers 功能。

方法 描述

void clearInterval(inlonghandle);

取消由句柄所确定的超时。

void clearTimeout(inlonghandle);

取消由句柄所确定的超时。

long setInterval(inanyhandler,inoptionalanytimeoutinany...args);

计划在指定的毫秒数之后重复运行的超时。注:你现在可以将其他参数直接传递到处理程序。如果处理程序是 DOMString,它被编译成 JavaScript。将句柄返回到超时。清除 clearInterval

long setTimeout(inanyhandler,在可选的任何超时中,在任何... 参数中);

计划在指定的毫秒数之后运行的超时。注:你现在可以将其他参数直接传递到处理程序。如果处理程序是 DOMString,它被编译成 JavaScript。将句柄返回到超时。清除 clearTimeout

在 IE10 Platform Preview 4 中对 Web Worker 的更新

Internet Explorer 10 Platform Preview Build 4 添加了每个进程 25 个 Web Worker 线程的限制。你可以在脚本中创建更多的 worker,但同时只有 25 个将处于活动状态。

如果达到最大线程数,创建 worker 将不会引发异常。调用总是成功,你可以添加处理程序并将消息发布给它。但是,在现有的 25 个线程之一变得可用之前,worker 可能不会启动。

 
  1. // Coding pattern before IE10 Platform Preview Build 4
  2. try {
  3. var worker = new Worker(url);
  4. } catch(ex) {
  5. // IE might throw...?
  6. }
  7.  
  8. // After IE10 Platform Preview Build 4
  9. var worker = new Worker(url);
  10. // Continue with confidence...

html5之web worker的更多相关文章

  1. 通过一次实验来了解HTML5的 Web Worker

    web worker 是运行在后台的 JavaScript,不会影响页面的性能. 当在 HTML 页面中执行脚本时,页面的状态是不可响应的,直到脚本已完成. web worker 是运行在后台的 Ja ...

  2. JS利用HTML5的Web Worker实现多线程

    需求:有一个长时间的斐波拉契的计算希望放在分线程中计算,计算的得到结果后再返回给主线程展示,再计算的时候不冻结页面 var number = 55;//传入分线程的参数 var worker = ne ...

  3. html5 web worker学习笔记(记一)

    (吐槽:浏览器js终于进入多线程时代!) 以前利用setTimeout.setInterval等方式的多线程,是伪多线程,本质上是一种在单线程中进行队列执行的方式.自从html5 web worker ...

  4. web worker 简介

    web worker 简介 通常,浏览器执行某段程序的时候会阻塞直到运行结束后在恢复到正常状态,而HTML5的Web Worker就是为了解决这个问题.通过worker线程完成密集计算,避免程序的阻塞 ...

  5. JavaScript多线程之HTML5 Web Worker

    在博主的前些文章Promise的前世今生和妙用技巧和JavaScript单线程和浏览器事件循环简述中都曾提到了HTML5 Web Worker这一个概念.在JavaScript单线程和浏览器事件循环简 ...

  6. 过段时间逐步使用HTML5新增的web worker等内容

    想来快2017年了,2013年前的手机应该很少有人用了,以后逐渐使用HTML5新增的高级API吧. 先把web worker的内容再熟悉一下,因为微软虚拟学院的'面向有经验开发人员的 JavaScri ...

  7. HTML5 Web Worker的使用

    Web Workers 是 HTML5 提供的一个javascript多线程解决方案,我们可以将一些大计算量的代码交由web Worker运行而不冻结用户界面. 一:如何使用Worker Web Wo ...

  8. 深入理解JS异步编程四(HTML5 Web Worker)

    >Web Workers 是 HTML5 提供的一个javascript多线程解决方案,我们可以将一些大计算量的代码交由web Worker运行而不冻结用户界面. 一:如何使用Worker We ...

  9. 深入HTML5 Web Worker应用实践:多线程编程

    HTML5 中工作线程(Web Worker)简介 至 2008 年 W3C 制定出第一个 HTML5 草案开始,HTML5 承载了越来越多崭新的特性和功能.它不但强化了 Web 系统或网页的表现性能 ...

随机推荐

  1. plugin

    http://wicky.nillia.ms/headroom.js/ http://makotot.github.io/sidebar/ http://www.nodebeginner.org/in ...

  2. org.quartz.utils.UpdateChecker Checking for available updated version of Quartz..

    <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</ ...

  3. 查看堵塞的SQL

    SELECT r.trx_id waiting_trx_id, r.trx_mysql_thread_id waiting_thread, r.trx_query waiting_query, b.t ...

  4. Wi-Fi定位,AP定位

    Wi-Fi实时定位系统 基于Wi-Fi的无线局域网实时定位系统(Wi-Fi RTLS)结合无线局域网络(WLAN).射频识别(RFID)和实时定位等多种技术,广泛地应用在有无线局域网覆盖的区域,实现复 ...

  5. -_-#微信内置JavaScript API WeixinJSBridge

    微信相关的 js 操作:分享.网络.菜单 微信内置JsAPI之WeixinJSBridge微信WeixinJSBridge API续

  6. 【转】如何开启notepad++函数列表功能

    原文网址:http://jingyan.baidu.com/article/4b07be3c41e05e48b380f3f6.html Notepad++是window下特有的一款开源编辑器软件,相信 ...

  7. 【转】android 中如何限制 EditText 最大输入字符数

    原文网址:http://blog.csdn.net/fulinwsuafcie/article/details/7437768 方法一: 在 xml 文件中设置文本编辑框属性作字符数限制 如:andr ...

  8. 海美迪Q5智能机顶盒的蓝牙功能

    虽然在硬件上,海美迪Q5智能机顶盒没有集成蓝牙模块,但是在软件系统上,Q5是支持蓝牙驱动的,所以它可以通过USB外接蓝牙适配器来扩展出蓝牙功能,简单来说,就是你另外买个蓝牙适配器,插到Q5上面,就能用 ...

  9. openStack 云平台使用一般杂记

    1. To launch an instance,you must at least specify the flavor,image name,network,security group,keyp ...

  10. sqlserver查看索引使用情况以及建立丢失的索引

    --查看表的索引使用情况SELECT TOP 1000o.name AS 表名, i.name AS 索引名, i.index_id AS 索引id, dm_ius.user_seeks AS 搜索次 ...