使用setTimeOut进行ajax调用

时间:2013-03-25 06:38:01

标签: php javascript asp.net ajax

我想使用ajax编写聊天应用程序。所以我需要每100毫秒(0.1秒)检查数据库中的用户消息表。如果我使用setTimeOut每隔100毫秒调用ajax会有什么问题吗?任何性能问题?任何陷阱或任何事情?

3 个答案:

答案 0 :(得分:0)

这是一个非常糟糕的主意。虽然它可能适用于您的本地计算机和少数用户,但它无法轻松扩展到更多用户。我建议你看看websockets和长轮询。

答案 1 :(得分:0)

更好的选择是使用Socket.IO。它使这项任务变得更加容易

Socket.IO使其成为跨浏览器解决方案

来自socket.io

的示例

服务器

var io = require('socket.io').listen(80);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

客户端(浏览器):

<script src="/socket.io/socket.io.js"></script>
<script>
  var socket = io.connect('http://localhost');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>

修改

对于PHP,phpwebsocket类非常适合客户端jquery plugin

答案 2 :(得分:0)

JavaScript知道两种定时器:setInterval和setTimeOut。 setInterval只是每100毫秒触发一次,setTimeOut会在前一个100毫秒后调用下一个调用。在调整应用时,您应该记住这种行为。您也可以考虑网络工作者,他们真正在一个单独的线程上完成他们的工作。他们传达基于消息的信息,这听起来是解决您问题的合适方案。确切的延迟(100毫秒或更长)是你真正需要尝试的东西。 John Resig的书显示,不同浏览器的实用计时器延迟相差很大,从21毫秒(IE9)到1毫秒(Opera)。