HTML5 Web Workers

web worker 是运行在后台的javascript,不会影响页面的性能
当在HTML页面中执行脚本时,页面的状态是不可响应的,直到脚本已完成。
web worker是运行在后台的javascript,独立于其他脚本,不会影响页面的性能。web worker在后台运行时,可以做任何事情:点击,选取内容。
1.实例
这里写图片描述

<p>计数: <output id="result"></output></p>
<button onclick="startWorker()">开始工作</button> <!--设置两个按钮,分别绑定事件-->
<button onclick="stopWorker()">停止工作</button>
<script>
var w;
function startWorker() {
    if(typeof(Worker) !== "undefined") { //浏览器支持we bworkers
        if(typeof(w) == "undefined") { //w 是未定义的,还没开始计数
            w = new Worker("demo_workers.js"); //创建一个对象
        }
        w.onmessage = function(event) {
            document.getElementById("result").innerHTML = event.data;
        };
    } else {
        document.getElementById("result").innerHTML = "抱歉,你的浏览器不支持 Web Workers...";
    }
}

function stopWorker() { 
    w.terminate(); //终止
    w = undefined;
}
</script>

demo_workers.js

var i=0;

function timedCount()
{
    i=i+1;
    postMessage(i);//它用于向 HTML 页面传回一段消息。
    setTimeout("timedCount()",500);
}

timedCount(); //加1计数,500毫秒调用一次

2**.Web Workers 和 DOM**
由于 web worker 位于外部文件中,它们无法访问下例 JavaScript 对象:
window 对象
document 对象
parent 对象

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值