美文网首页
webworker的作用

webworker的作用

作者: 浅秋_6672 | 来源:发表于2018-11-26 10:05 被阅读0次

    一、什么是 页面阻塞?怎么解决?

    页面阻塞:

    大多数浏览器是使用单线程处理 UI更新 和 JavaScript 运行等多个任务的,而单线程就意味着同一时间只能由一个任务被执行;JavaScript 加载、解析和运行完,浏览器才能去响应处理其它事情。(不论JavaScript是在内联还是外部引入都一样)

    解决方法:

    (1)为了让html文档在解析时,尽量地快,常规的做法是将<script>标签放到</body>标签的前面,这样就不会阻塞html中其他资源的下载了。

    (2)无阻塞脚本技术,主要分为两大类:

       1、 defer和 HTML5中的async;(只对外链有效)

    defer模式 <script type="text/javascript" src="x.min.js" defer="defer"></script>

    async模式 <script type="text/javascript" src="x.min.js" async="async"></script>

      当解析器遇到设置defer或者async属性的<script>元素时,它开始下载脚本,并继续解析文档。脚本会在它下载完成后尽快执行,但是解析器没有停下来等待他下载。

    defer:用于开启新的线程下载脚本文件,并使脚本在文档解析完成后执行。

    async:HTML5新增属性,用于异步下载脚本文件,下载完毕立即解释执行代码。

       2、  动态创建script为dom元素。

      (3) ajax:使得页面在等待服务器响应的这段时间内不再发生阻塞,但是这仍然没有改变代码单线程执行的本质。

    (3)web worker: 允许JavaScript创建多个线程。

    ------------------------------------------------------------------------------------------------------------------------------------

    二、web worker

    1、概念:

    单线程:同一时间,只能做一件事。

    webWorker(工作线程):

    它允许开发人员编写能够长时间运行而不被用户所中断的后台程序,去执行事务或者逻辑,并同时保证页面对用户的响应。

    简而言之,就是允许JavaScript创建多个线程,但是子线程完全受主线程控制,且不得操作DOM。从而,可以用webWorker来处理一些比较耗时的计算。

    web worker作用 :

    在浏览器中javascript的执行是单线程的,页面上的javascript在执行时会阻塞浏览器的响应,这非常影响用户体验,所以ajax应运而生了。ajax的出现使得页面在等待服务器响应的这段时间内不再发生阻塞,但是这仍然没有改变代码单线程执行的本质,这也意味着我们依旧不能把耗费时间的复杂运算放在页面上执行。而web worker的出现弥补了这个缺点。

    页面上单线程执行的javascript是主线程(我们通常写的javascript都在主线程中执行),new出来的web worker对象为子线程,只有主线程中的代码执行时会导致阻塞,子线程则不会,这表示部分耗费时间的复杂运算完全可以从后台挪到前台来完成。

    2、Worker对象分为两种?

    专用式( dedicated )Web Worker:只能被单个页面使用,专为当前页面服务。

    共享式( shared )Web Worker:可以在被多个页面使用。

    3、web worker常用API:

    1、postMessage(data)

    子线程与主线程之间互相通信使用方法,传递的data为任意值。

    2、terminate()

    主线程中终止worker,此后无法再利用其进行消息传递。注意:一旦terminate后,无法重新启用,只能另外创建。

    3、message

    当有消息发送时,触发该事件。且,消息发送是双向的,消息内容可通过data来获取。

    message使用,可见terminate中的demo

    4、error

    出错处理。且错误消息可以通过e.message来获取。

    注意:worker线程从上到下同步运行它的代码,然后进入异步阶段来对事件及计时器响应,如果worker注册了message事件处理程序,只要其有可能触发,worker就一直在内存中,不会退出,所以通信完毕后得手动在主线程中terminate或者子线程中close掉,但如果worker没有监听消息,那么当所有任务执行完毕(包括计数器)后,他就会退出。

    webWorker之常用API

    4、web worker 执行流程:

    (1)按钮的点击事件中创建了Worker对象,并给它指定了Javascript脚本文件——demo_worers.js;

    (2)并且给Worker对象绑定了一个“message”事件。该事件会在后台代码(demo_workers.js)向页面返回数据时触发。“message”事件可以通过event.data来获取后台代码传回的数据。

    (3)将数据追加到页面

    例:

    <!DOCTYPE html><html><body> <p>Count numbers: <output id="result"></output></p> <button onclick="startWorker()">Start Worker</button> <button onclick="stopWorker()">Stop Worker</button> <input type="text" value=""/><script>varw;

    //开始functionstartWorker(){if(typeof(Worker) !=="undefined") {你if(typeof(w) ==="undefined") {      w = new Worker("demo_workers.js");}    w.onmessage =function(event){      document.getElementById("result").innerHTML =event.data;    };  }else{    document.getElementById("result").innerHTML ="Sorry, your browser does not support Web Workers...";  }}

    //停止functionstopWorker(){

    //强制终止执行中的Web Worker。Worker对象提供了terminate()来终止自身执行任务,被终止的Worker对象不能被重启或重用,我们只能新建另一个Worker实例来执行新的任务。w.terminate();}</script></body></html>

    demo_workers.js代码:

    function timedCount () {

      for (var i = 0; i < 10000000000; i++) {

        if (i % 100000 === 0) {

          postMessage(i);

        }

      }

    }

    timedCount();

    注意: web worker 脚本位于外部JS文件中,所以无法访问下列HTML相关的JS 对象。

    window 对象

    document 对象

    parent 对象

    sessionStorage、localStorage等

    只要是HTML的对象都不能访问 比如不能在web worker中使用H5的sessionStorage等。如果使用则报错 sessionStorage is not define 没有定义

    相关文章

      网友评论

          本文标题:webworker的作用

          本文链接:https://www.haomeiwen.com/subject/ejmvqqtx.html