现在的位置: 首页 > 综合 > 正文

HTML5之Worker Thread

2013年08月30日 ⁄ 综合 ⁄ 共 1361字 ⁄ 字号 评论关闭

传统网页中嵌入的JSP语言都是执行在UI的上下文中,一般来说这种JSP处理的都是简单逻辑,没啥问题,随着Web复杂度越来高,JSP能处理的事情也越来越复杂,如果JSP计算量比较大的话,这就会导致UI页面假死。HTML5中的WorkerThread可以缓解这个问题,Worker Thread通过UI thread创建一个新的线程来进行计算,消息和结果通过Web Message来进行通讯,由于这种异步性,UI便可以较为流畅地响应新到来的事件。

调用过程如下:

1.新的工作线程执行体放在一个单独的JS文件中,比如worker.js.

  1. self.onmessage = function(event){  
  2.         //do the real compute ---begin  
  3.         //  
  4.         //do the real compute ---end  
  5.         //post message back to UI thread  
  6.     self.postMessage(XXXX);  
  7. };  

2.在UI的执行线程中生成一个worker对象,worker对象的构造函数参数就是worker.js

  1. var worker = new Worker("worker.js");  

3.下面就可以发送消息让worker干活了

  1. worker.postMessage("perise");  

4.活干完了给UI发送消息,也就是第一步中的

5.UI进行响应

  1. worker.onmessage = function(event){  
  2.                         //update UI here  
  3.             };  

Notes:

*在Chrome中调试的时候会出现SECURITY_ERR: DOM Exception 18,传说是Webkit的bug,没有细究,可以通过搭建一个本地的HTTP服务器来解决,把HTML文件放到本地服务器上就可以绕开这个安全问题了,我使用的是WAMP

*也许是为了控制Worker Thread的复杂度,Chrome的Worker Thread中不能再生成新的worker thread,其实这个很容易绕开,发送一个消息到UI中,让UI生成新的Worker Thread就好,Firefox可以支持subworker,但Chrome是可以支持sharework,这种shareworker可以共享JS文件里面的全局数据。

文章转自: http://software.intel.com/zh-cn/blogs/2011/11/22/html5worker-thread/

抱歉!评论已关闭.