HTML5-WebWorker

本文通过一个具体的实例展示了如何使用 HTML5 的 WebWorker 进行后台任务处理,包括主线程与 Worker 线程之间的通信及定时更新时间戳的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


 

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>HTML5-WebWorker</title>
    </head>
    <body>
        
        web worker实时时间:<div id="workerTime"></div>
        <br />
        主线程获取当前时间:<div id="curTime"></div>
        <button onclick="mainthread()">主线程获取时间</button>
    
        <script type="text/javascript">
            /*
             * Web worker的运行原理和两种线程的详细说明 : http://www.ibm.com/developerworks/cn/web/1112_sunch_webworker/
             */
            var interval;
            if (typeof Worker != undefined) {
                var worker = new Worker("js/webworker.js");
                worker.onmessage = function (event)
                {
                    document.getElementById("workerTime").textContent = event.data;
                }
                interval = setInterval('worker.postMessage("1000000")', 1000);
            }
    
            function mainthread() {
                document.getElementById("curTime").textContent = new Date();
            }
            function stop() {
                clearInterval(interval);
           worker.terminate();
            }
            setTimeout(stop, 60000);//60秒之后清理interval
        </script>
        
    </body>
</html>

 

webworker.js

onmessage = function(event) {
    var msg = event.data;
    for (var i = 0; i < msg; i++) {
        if (!!console && i % 500 == 0) {
            console.info(i);
        }
    }
    var d = new Date();
    postMessage(d);
}

 

转载于:https://www.cnblogs.com/blog-leo/p/4457707.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值