HTML 5 服务器发送事件EventSource如何让其每秒执行一次?

W3C的例子:http://www.w3school.com.cn/tiy/t.asp?f=html5_sse

例子是每三秒执行一次,能否每秒执行一次?

<!DOCTYPE html>
<html>
<body>


<h1>获得服务器更新</h1>




<div id="result"></div>




<script>
if(typeof(EventSource)!=="undefined")
  {
  var source=new EventSource("http://www.w3school.com.cn/example/html5/demo_sse.php");
  source.onmessage=function(event)
    {
    document.getElementById("result").innerHTML+=event.data + "<br />";
    };
  }
else
  {
  document.getElementById("result").innerHTML="Sorry, your browser does not support server-sent events...";
  }
</script>



</body>
</html>

已邀请:

xianjijida7218

赞同来自:

EventSource是html5监听后端更新的api 也就是说 ,触发的频率是由后端决定的
所以你可以设置后端更新为一秒一次就好了

Paris0008

赞同来自:

EventSource对象并不能够自行设定刷新时间,这依赖于浏览器的具体实现,比如在Chrome中的刷新时间是3秒,但是在Firefox中刷新时间为5秒。

事实上,如果你可以控制服务器的话,可以在服务器端使用retry头信息,指定通信的最大间隔时间。

服务器收到请求时,并不会立即回复这个请求,只有当服务器需要推送数据的时候,才会以data:'message'这样的格式返回信息,但是此时利用的是分块传输机制刷新缓存,并不释放连接,以便下一次继续推送。

所以这里有一个坑需要注意,如果你的服务器使用的是Nginx而不是Apache,那么需要关闭相应请求的buffer才能达到预期效果。

lujiaren

赞同来自:

浏览器对EventSource有最小时间的阀值,即使后端设为1秒也没有用。

要回复问题请先登录注册