轮询与长轮询的理解和简单代码实现

1、轮询的实现原理:开发人员在客户端使用定时器,每隔指定时间向服务器发起一次请求,服务器收到请求后检查是否有新数据或事件,并将其返回给客户端作为响应。客户端收到响应后,处理数据或事件,并随后发送下一个请求。

2、代码实现:

// 客户端代码
function getNews() {
  fetch('/api/data')
    .then(res=> {
      // 处理服务器响应的数据
      console.log(res.data)
      // 继续下一次轮询
      setTimeout(getNews, 5000);
    });
}

// 开始轮询
getNews();

3、长轮询的实现原理:客户端发送一个HTTP请求给服务器,并保持连接打开,直到服务器有新的数据或事件时才返回响应给客户端。在这期间,服务器会一直保持连接打开,直到超时或有新数据或事件。

// 客户端代码
function longGetNews() {
  fetch('/api/data')
    .then(res=> {
      if (res.status === 204) {
        // 服务器返回204表示没有新数据或事件,继续进行长轮询
        longGetNews();
      } else if (res.status === 200) {
        // 服务器返回200表示有新数据或事件,处理数据并进行下一次长轮询
        .then(res=> {
          console.log(res.data);

          // 继续进行长轮询
          longGetNews();
        });
      }
    });
}

//开始长轮询
longGetNews()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值