使用以下代码:
HTML文件:
<!DOCTYPE html>
<html>
<head>
<title></title>
<!--<script type="text/javascript" src="worker.js"></script>-->
<script type="text/javascript" src="run.js"></script>
</head>
<body>
<div id='log'></div>
</body>
</html>
run.js:
window.onload = function(){
var worker = new Worker('worker.js');
var log = document.getElementById('log');
log.innerHTML += "<p>"+"test"+"</p>";
worker.addEventListener('message', function(e) {
//alert(e.data);
log.innerHTML += '<p>' + e.data + '</p>';
}, false);
for(var i=1; i<21;i++){
worker.postMessage(i);
}
};
worker.js
self.addEventListener('message', function(e) {
self.postMessage(e.data);
}, false);
输出是我所期望的1到20的列表,但如果我取消注释run.js消息监听器中的警报调用,它将打印输出20到1.这是因为警报导致写入页面的延迟,并且消息处理在堆栈中备份,所以最后一个是第一个关闭?或者是别的什么.
解决方法:
是的,这是因为“alert()”.它阻止在工作者监听器块内进一步执行代码.换句话说,代码:
log.innerHTML += '<p>' + e.data + '</p>';
只有在按下警告框的模态窗口上的“确定”按钮后才会执行,按此顺序按下它们,按此顺序更改“log.innerHTML”,因此按降序按下它们为什么你得到这个结果.如果您不使用警报消息,一切顺利.
标签:javascript,web-worker 来源: https://codeday.me/bug/20190530/1183405.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。