zoukankan      html  css  js  c++  java
  • js Worker 线程

    JavaScript 语言采用的是单线程模型,也就是说,所有任务只能在一个线程上完成,一次只能做一件事。前面的任务没做完,后面的任务只能等着。随着电脑计算能力的增强,尤其是多核 CPU 的出现,单线程带来很大的不便,无法充分发挥计算机的计算能力。
    Web Worker 的作用,就是为 JavaScript 创造多线程环境,允许主线程创建 Worker 线程,将一些任务分配给后者运行。在主线程运行的同时,Worker 线程在后台运行,两者互不干扰。等到 Worker 线程完成计算任务,再把结果返回给主线程。这样的好处是,一些计算密集型或高延迟的任务,被 Worker 线程负担了,主线程(通常负责 UI 交互)就会很流畅,不会被阻塞或拖慢。

    基本用法

    主线程

    // new Worker(url) url是跟主线程同源的worker线程文件,不能跨域
    var worker = new Worker('test.worker.js');
    worker.onmessage = function (event) {
        let data = event.data;
        alert(JSON.stringify(data));
    }
    // 向Worker线程传递数据
    worker.postMessage({ cmd: 'time' });
    

    Worker线程

    self.onmessage = function (event) {
        let param = event.data;
        switch (param.cmd) {
            case 'time':
                self.postMessage({ cmd: 'time', data: new Date() })
                break;
        }
    }
    

    Demo:
    简单Demo

    参考:
    Web Worker 使用教程
    js Worker 线程

  • 相关阅读:
    [luogu p2482] [SDOI2010]猪国杀
    [luogu p2296] 寻找道路
    左右布局(备用复制)
    导出Excel
    流式布局 及 媒体查询
    echarts设置(持续更新)
    解决Vue中watch首次进入路由不触发的问题
    Math.random
    Vue的拖拽
    使的dialog上下左右居中(弹框居中)
  • 原文地址:https://www.cnblogs.com/kw13202/p/10430625.html
Copyright © 2011-2022 走看看