前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WebWorker如何使用?

WebWorker如何使用?

作者头像
CherishTheYouth
发布2020-12-18 11:08:02
2.9K0
发布2020-12-18 11:08:02
举报
文章被收录于专栏:Vue技术实践Vue技术实践

Web Worker技术

Web Worker为Web内容在后台线程中运行脚本提供了一种简单的方法。线程可以执行任务而不干扰用户界面。

web worker 是运行在后台的 JavaScript,不会影响页面的性能。

1 用法

1.1 创建Web Worker
代码语言:javascript
复制
let worker = new Worker('workerJsFile.js')// 里面写在后台线程执行的js文件 
1.2 onmessage方法

worker.onmessage() 用于监听 线程之间 的消息,一旦其中一方 调用 postMessage 方法发送消息,则另一方可通过 onmessage() 方法监听到,然后通过 event.data 参数获取到另一方发送的消息;

worker.onmessage()处理函数允许我们在任何时刻,一旦接收到消息就可以执行一些代码,代码中消息本身作为事件的data属性进行使用;

1.3 postMessage方法

worker.postMessage() 用于在线程之间发送消息;

1.4 注意

  • 在主线程中使用时,onmessage()postMessage() 必须挂在worker对象上,而在worker中使用时不用这样做。原因是,在worker内部,worker是有效的全局作用域。
  • 当一个消息在主线程和worker之间传递时,它被复制或者转移了,而不是共享。
1.5 terminate 方法

worker.terminate() 用于终止 worker

如果你需要从主线程中立刻终止一个运行中的worker,可以调用worker的terminate() 方法;

worker 线程会被立即杀死,不会有任何机会让它完成自己的操作或清理工作。

1.6 close 方法

而在worker线程中,workers 也可以调用自己的 close() 方法进行关闭

代码语言:javascript
复制
close()

2 demo

2.1 描述

在后台执行一个计时程序,计时到20停止,或者手动点击停止计时停止

2.2 主线程
代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <div>
    <p>计数:<output id = "count"></output></p>
    <button onclick="startWorker()">开始Worker</button>
    <button onclick="stopWorker()">停止Worker</button>
    <button onclick="resetCountTime(5)">重置计时时间</button>
  </div>
</body>
</html>
<script>
  let worker;
  const startWorker = () => {
    // 判断浏览器是否支持 Web Worker 属性
    if (typeof Worker !== 'undefined') {
      if (typeof worker == 'undefined') {
        worker = new Worker('./workerDemo.js')
      }
      worker.onmessage = (event) => {
        document.getElementById('count').innerHTML = event.data
      }
    } else {
      document.getElementById('count').innerHTML = "浏览器不支持web worker属性"
    }
  }

  const stopWorker = () => {
    worker.terminate()
  }
  const resetCountTime = (count) => {
    if (worker) {
      worker.postMessage(count)
    } else {
      document.getElementById('count').innerHTML = "web worker 不存在"
    }
  } 
</script>
2.3 worker线程
代码语言:javascript
复制
let count = 0
const oneSecond = 1000 //ms

const countTime = () => {
  count++
  console.log(count)
  postMessage(count)
  if (count > 10) {
    // 自己终止后台线程
    close()
  }
  setTimeout("countTime()", oneSecond)
}

countTime()

onmessage = (event) => {
  count = event.data
}
2.4 演示:

3.引入脚本与库

Worker 线程能够访问一个全局函数importScripts()来引入脚本,该函数接受0个或者多个URI作为参数来引入资源;以下例子都是合法的:

代码语言:javascript
复制
importScripts();                        /* 什么都不引入 */
importScripts('foo.js');                /* 只引入 "foo.js" */
importScripts('foo.js', 'bar.js');      /* 引入两个脚本 */
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-12-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Web Worker技术
    • 1 用法
      • 1.1 创建Web Worker
      • 1.2 onmessage方法
      • 1.3 postMessage方法
      • 1.4 注意
      • 1.5 terminate 方法
      • 1.6 close 方法
    • 2 demo
      • 2.1 描述
      • 2.2 主线程
      • 2.3 worker线程
      • 2.4 演示:
    • 3.引入脚本与库
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档