![](/img/trans.png)
[英]angular2 change detection after Worker.onmessage does not work as expect
[英]Does the event object on worker.onmessage ever contain anything interesting apart from data?
添加回調以捕獲通過Web worker管道傳輸的數據時,通常會執行以下操作:
worker.addEventListener("message", function(event) {
var data = event.data;
// Do something with data
...
});
我從未觸及任何其他屬性,當我將事件對象記錄到控制台時,我沒有注意到任何有趣的東西。 由於Event
對象的創建給消息傳輸增加了一些開銷,我問:
問: webworker回調中的Event
對象有什么有趣的,或者我們是否只使用event.data
?
在這種情況下,事件對象遵循MessageEvents接口,該接口包含以下屬性:
data屬性必須返回它初始化的值。 創建對象時,必須將此屬性初始化為null。 它表示正在發送的消息。
origin屬性必須返回它初始化的值。 創建對象時,必須將此屬性初始化為空字符串。 它在服務器發送的事件和跨文檔消息傳遞中表示發送消息的文檔的來源(通常是文檔的方案,主機名和端口,但不包括其路徑或片段標識符)。
lastEventId屬性必須返回它初始化的值。 創建對象時,必須將此屬性初始化為空字符串。 它在服務器發送的事件中表示事件源的最后一個事件ID字符串。
source屬性必須返回它初始化的值。 創建對象時,必須將此屬性初始化為null。 它在跨文檔消息傳遞中表示消息來自的Window對象的瀏覽上下文的WindowProxy。
ports屬性必須返回它初始化的值。 創建對象時,必須將此屬性初始化為null。 它表示在跨文檔消息傳遞和通道消息傳遞中發送的MessagePort數組(如果有)。
有關詳細信息,請參閱規范。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.