WebSocket 和 AJAX 轮询是实现服务器向客户端推送消息的两种常见方法。
WebSocket
WebSocket 是一种双向通信协议,它允许服务器主动向客户端推送消息,而不需要客户端发起请求。
JavaScript 示例代码:
var ws = new WebSocket("ws://yourserver.com/path");
ws.onopen = function() {
console.log('WebSocket connected');
};
ws.onmessage = function(event) {
console.log('Message received: ' + event.data);
};
ws.onclose = function() {
console.log('WebSocket closed');
};
AJAX 轮询
AJAX 轮询是客户端定时发送 HTTP 请求到服务器,以检查是否有新消息的方法。
JavaScript 示例代码:
function poll() {
$.ajax({
url: "http://yourserver.com/path",
success: function(data) {
console.log('Message received: ' + data);
// 继续轮询
setTimeout(poll, 3000); // 轮询间隔3秒
},
error: function() {
console.log('Error polling');
// 重新连接
setTimeout(poll, 3000); // 如有需要,可以增加错误处理
}
});
}
// 开始轮询
poll();
在选择 WebSocket 还是 AJAX 轮询时,需要考虑实时性需求、兼容性要求、服务器压力等因素。通常情况下,WebSocket 是更优的选择,因为它更高效、实时,并且有较少的开销。但在不支持 WebSocket 的旧浏览器上,轮询方法可能是唯一选择。