zoukankan      html  css  js  c++  java
  • Js如何实现多线程

    JS如何实现多线程

       JS为我们提供了一个Worker的类,它的作用就是为了解决这种阻塞的现象。当我们使用这个类的时候,它就会向浏览器申请一个新的线程。这个线程就用来单独执行一个js文件。

    var worker = new Worker(js文件路径);    //这个语句就会申请一个线程用来执行这个js文件。
    

       在主线程中有一些方法来实现对新线程的控制和数据的接收。在这里,我们只说比较常用的几个方法。

     //postMessage(msg);
     //postMessage方法把在新线程执行的结果发送到浏览器的js引擎线程里
     worker.onmessage = function(){
         //获取在新线程中执行的js文件发送的数据 用event.data接收数据
         console.log( event.data )
     };
     setTimeout( function(){
         worker.terminate();
         //terminate方法用于关闭worker线程
     },2000)
        
     setTimeout( function(){
         worker = new Worker("js/test22.js");
         //再次开启worker线程
     },3000)
    

        新线程中使用postMessage()方法可以向主线程中发送一些数据,主线程中使用worker的onmessage事件来接收这些数据,这样就实现了js的多线程执行和多线程之间数据的传递。

  • 相关阅读:
    PHPStorm 支持 Element UI 语法提示
    npm
    谷歌浏览器插件
    RBAC
    git 知识点
    Laradock ppa加速
    vscode插件
    临时解决执行 Composer Install 返回 Killed 的问题
    单例设计模式(3种实现方式)
    log4j.properties 详解与配置步骤
  • 原文地址:https://www.cnblogs.com/yxkNotes/p/13931736.html
Copyright © 2011-2022 走看看