理解JavaScript中worker事件api
作者:bea
如果你不是很了解Event事件,建议先这篇文章《理解javascript中DOM事件》。
首先,我们需要实例一个Worker的对象,浏览器会根据新创建的worker对象新开一个接口,此接口会处理客户端与indexedDB数据库之间的通信。这里的数据库是指浏览器数据库。如果,你需要判断浏览器是否支持worker对象,详见如下代码。或者浏览器是否支持indexedDB数据库,详见同下,二者判断最好选择前者。因为IE不支持indexedDB 。
if(window.Worker){ dosomething }
// Worker
window.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB;
if(!window.indexedDB){ dosomething }
// indexedDB
之后,worker对象会通过postMessage线程向indexedDB数据库发送数据,当indexedDB数据库接收到客户端发送的数据,首先把数据的键值储存并记录到indexedDB数据库表里面,其实相当于把数据保存在一张结构完整的表内。
于是,indexedDB数据库会把接收到的数据值扔给新接口处理,当新接口获得数据并解析之后,会通过postMessage扔回一条数据给数据库,数据库接收返回的数据处理的方式和上面一样,此时indexedDB数据库会把返回的数据扔给客户端接受参数的onmessage线程,主线程后面onmessage线程主要是接收传回的数据。
var txt1 = document.querySelector("#txt1");
var txt2 = document.querySelector("#txt2");
var result = document.querySelector("#result");
window.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;
if(!window.indexedDB)
{
console.log("你的浏览器不支持IndexedDB");
}
if(window.Worker){
var _this = new Worker("../../js/build/scroll_ten1.js");
txt1.onchange = function(){
_this.postMessage([txt1.value,txt2.value]); // e = [txt1.value,txt2.value]
console.log("message post to work");
}
txt2.onchange = function(){
_this.postMessage([txt1.value,txt2.value]); // e = [txt1.value,txt2.value]
console.log("message post to work");
}
_this.onmessage = function(s){ //接收到的数据 e
result.textContent = s.data;
}
}
onmessage = function(e){ //e接收Worker.postmessage传的参数
var s = (e.data[2]*e.data[1]);
var workerResult = "result : " + s;
postMessage(workerResult); //Worker.onmessage进行回调workerResult参数
}
想必大家看了以上的分析之后,肯定在想用Worker能做什么?对于这个问题,目前能解决线程的非阻塞问题,如何说起,当用户改变browser的的尺寸、以及拖动浏览器时,主线程访问后台数据时,并不会中断数据之间的进程。
支持Worker的browser有哪些?
分享一个链接caniuse,通过这个工具你能更加全面的看到各个浏览器的(hack)。
// *注Worker的首字母必须是大写的
// *注Worker的脚本目录必须是HTML能够访问到的目录
以上就是本文的全部内容,希望对大家深入理解JavaScript中worker事件api有所帮助。
猜你喜欢
您可能感兴趣的文章:
- 干货分享:让你分分钟学会javascript闭包
- javascript生成img标签的3种实现方法(对象、方法、html)
- 谈谈我对JavaScript中typeof和instanceof的深入理解
- JavaScript中Window对象的属性及事件
- JavaScript字符串删除重复字符的方法
- JavaScript如何实现在文本框(密码框)输入提示语
- jquery实现图片预加载
- 基于jquery实现图片相关操作(重绘、获取尺寸、调整大小、缩放)
- 使用堆实现Top K算法(JS实现)
- 原生js和jQuery实现淡入淡出轮播效果
- jQuery实现模仿微博下拉滚动条加载数据效果
- 尝试动手制作javascript放大镜效果
- js操作cookie保存浏览记录的方法
- js实现跨域的多种方法
- jquery.cookie.js用法实例详解
- 理解javascript中try...catch...finally
- javascript实现简单加载随机色方块
- 学习JavaScript鼠标响应事件
- 理解javascript中DOM事件