做websocket应用时有这样一种需求:
ws.onmessage = function(e) {
}
这个要响应做普通异步数据处理,但偶尔有同步处理的需求,于是我在ws.onmessage里自定义了一个事件:
ws.onmessage = function(e) {
//...
myData = procData(e.data);//处理我想要的数据
//以下发送自定义消息
var evt = new CustomEvent('Message', {
detail: {data: myData},
});
window.dispatchEvent(evt);
}
var onMessage;
window.addEventListener("Message",onMessage,false);
//直接下面这样是有响应的
onMessage = function(e) {
console.log(e.detail.data);
}
//但如果放到Promise内就没响应了,更奇怪的是ws.onmessage这个消息就会有响应
function ReceiveMessage() {
return new Promise((resolve) => {
onMessage = function(e) {
console.log(e.detail.data);
resolve(e.detail.data);
}
//ws.onmessage = function(e) {
// 如果用这一段代码就有响应
//}
});
}
async function func1() {
//...
var ret = await ReceiveMessage();
return (ret);
}
我是业余玩玩JS的,并不怎么会,很多代码都是网上找来的,谁能告诉我这是为什么?
我的目的就是要func1等到WS收到数据后才能返回,否则达到设定时间后超时返回