写博客主要是用来总结、巩固知识点,加深本身对这个知识点的理解。同时但愿帮助到有须要的人。若有不正确的地方。能够在评论区指出。大家的支持。是我不断进步的源泉。html
这是一道面试题,刚开始面试官为我前端如何处理大量数据。我第一时间就脱口而出用分页呀!面试官说那是从后台的角度来考虑的。从前端的角度呢?emmmmm...我思考了一下,分批加载,懒加载。监听用户的滑动分批显示数据。接着又问,若是我要对这些大量数据作计算作处理呢,同时又不能让页面崩掉、假死。该如何操做呢?顿时我就懵逼了,这。。这个要怎么操做呀。心想作计算啥的不是应该在后台作完吗!前端
并且怎么可能一会儿给前端这么多数据吗,~~web
抱怨归抱怨,吐槽归吐槽~~面试
后来问了下面试官,实现的大概思路。后来面试官说是经过worker来作子线程来实现的。bash
好,那咱们就来学习一下这个worker网络
运行者 Worker 接口是Web Workers API的一部分,表明一个后台任务,
它容易被建立并向建立者发回消息。建立一个运行者只要简单的调用Worker()构造函数,指定一个脚本,在工做线程中执行。(引自MDN)
复制代码
看概念可能有点枯燥,通俗点讲就是:由于js是单线程运行的,在遇到一些须要处理大量数据的js时,可能会阻塞页面的加载,形成页面的假死。这时咱们可使用worker来开辟一个独立于主线程的子线程来进行哪些大量运算。这样就不会形成页面卡死。也说明 worker能够用来解决大量运算是形成页面卡死的问题。函数
const worker=new Worker(aURL, options)
复制代码
它有两个参数:post
aURL(必须)是一个DOMString 表示worker 将执行的脚本的URL。它必须遵照同源策略。学习
options (可选)它的一个做用就是指定 Worker 的名称,用来区分多个 Worker 线程ui
Worker.onerror:指定 error 事件的监听函数
Worker.onmessage:指定 message 事件的监听函数,发送过来的数据在Event.data属性中。
Worker.onmessageerror:指定 messageerror 事件的监听函数。发送的数据没法序列化成字符串时,会触发这个事件。
Worker.postMessage():向 Worker 线程发送消息。
Worker.terminate():当即终止 Worker 线程。
分配给 Worker 线程运行的脚本文件,必须与主线程的脚本文件同源。
Worker 线程所在的全局对象,与主线程不同,没法读取主线程所在网页的 DOM 对象,也没法使用document、window、parent这些对象。可是,Worker 线程能够navigator对象和location对象。
Worker 线程和主线程不在同一个上下文环境,它们不能直接通讯,必须经过消息完成。
Worker 线程不能执行alert()方法和confirm()方法,但可使用 XMLHttpRequest 对象发出 AJAX 请求。
Worker 线程没法读取本地文件,即不能打开本机的文件系统(file://),它所加载的脚本,必须来自网络。
求斐波纳茨数列的第38项
<div style="width:100px;height:100px;background-color:red;"></div>
document.querySelector('div').onclick=function(){
console.log('hello world');
}
function fibonacci(n){
return n<2?n:arguments.callee(n-1)+arguments.callee(n-2);
}
console.log(fibonacci(38));
复制代码
<div style="width:100px;height:100px;background-color:red;"></div>
var worker=new Worker('worker.js');
worker.postMessage(40);
worker.onmessage=function(event){
var data=event.data;
console.log(data)
};
worker.onerror=function(event){
console.log(event.fileName,event.lineo,event.message);
};
复制代码
<!--worker.js-->
self.onmessage = function (event) {
var data = event.data;
var ans = fibonacci(data);
this.postMessage(ans);
};
function fibonacci(n) {
return n < 2 ? n : arguments.callee(n - 1) + arguments.callee(n - 2);
}
复制代码
身边有电脑的小伙伴能够把上面代码复制到电脑上运行下,对比下,看下效果。就会明白这worker的做用了。
我这里记录的可能有点粗糙,更详细的能够看下面这几篇文章(固然,我是参考这几篇文章的了)
写的很差的地方,还请小伙伴们再评论区提出哦!