次のコード:ウェブワーカーのpostMessage工程順
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のリストを期待していますrun.jsメッセージリスナーでアラートコールのコメントを外すと、代わりに20対1が出力されます。これは、ページへの書き込みの遅れを引き起こすアラートとメッセージ処理がスタックにバックアップされるため、最後のものが最初のものであるためですか?それとも何か他のものですか?
おもしろい事実:Firefoxでは、私が20,19,18、...をあなたの説明どおりに見ています。 Chromeでは1、2、3、... – h0b0