我已经设法让 websockets 在使用 Chrome 的 webworker 中工作,但仅用于接收数据。当我尝试发送数据时出现 DOM 异常,有人成功发送数据了吗?
这就是我为网络 worker 准备的东西。
self.addEventListener('message', function(e) {
var data = e.data;
switch (data.cmd) {
case 'init':
self.postMessage("Initialising Web Workers...");
testWS();
break;
default:
self.postMessage('Unknown command: ' + data.msg);
};
}, false);
function testWS() {
var connectionAddr = "ws://localhost:8003";
var socket = new WebSocket(connectionAddr);
socket.onmessage = function(event) {
self.postMessage('Websocket : ' + event.data);
};
socket.onclose = function(event) {
};
function send(message) {
socket.send(message);
}
send("hello"); //Here is where the exception is thrown
}
最佳答案
在发送第一条消息之前,您必须监听 onopen websocket 事件。
socket.onopen = function(){
// send some message
};
关于javascript - Webworker 中的 HTML5 Websocket,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17998011/