【发布时间】:2019-10-24 07:55:31
【问题描述】:
我有一个页面,在收到websocket 后,它会通过javascript 执行某些操作。仅当在上次和我想要的时间之间没有收到 websocket 时,我希望此页面在一段时间后重新加载。
<script>
if ("WebSocket" in window) {
var ws = new WebSocket('ws://192.168.33.1:5000');
var variableSpan = document.getElementById('variable');
ws.onmessage = function (event) {
var message = JSON.parse(event.data);
console.log(message);
jQuery('#variable').empty();
$(function () {
$.get(message.variable, function (data) {
$("#variable").append(data);
});
});
setTimeout(function () {
window.location.reload(); // you can pass true to reload function to ignore the client cache and reload from the server
}, 10000);
}
}
</script>
我尝试了类似的方法,但它似乎不起作用。我会很感激一些帮助:)
【问题讨论】:
-
在`window.location.reload()`之前检查
if(ws.readyState === WebSocket.CLOSED) -
每次收到消息都需要清除之前的超时时间。
-
另外,如果你因为websocket连接问题而这样做,你可以简单地创建一个新的websocket而不是刷新页面。
-
连接错误我不需要这个。在这种情况下,这只是用户“不活跃”的情况
标签: javascript jquery websocket page-refresh