JS解决页面多次,重复请求 的2个方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS解决页面多次,重复请求 的2个方法相关的知识,希望对你有一定的参考价值。

  最近的一个case,在web页下,鼠标向下滚动翻页动态请求数据的时候。一般都是判断当前页面距离顶部的高度与整个html的长度之差来决定是否请求下一页的数据。

  如果不进行相应处理,滑动事件会触发多次,导致请求多次或者重复请求(取决于代码设计)

  思路1: 滑动到下方第一次触发请求后,移除滑动监听,等待请求返回,继续监听滑动事件。

  思路2: 对于一次滑动有产生多次不重复的请求的情况。可以让这些请求都进入队列,滑动时判断标志位,为真则取出队列第一个请求并执行,为假则不执行。待请求返回时设置标志位true。具体如下:

技术分享

// 在异步请求返回处加上下面这句
oneRequest.setResolve("functionname");

//在产生重复请求处写上
oneRequest.singleRequest(functionname,[param1,param2,param3]);

functionname 函数中必定是一个异步请求。


var single = function(){
    this.paramList = [];
    this.callfun = true;
    this.id = 0;
}
single.prototype.duplicateRequest = function(callback, params){
  this.paramList.push({"Funcname": callback.name, "params": params});
  if(this.callfun){
      callback(this.paramList[this.id++].params);
      this.callfun = false;
  }
}
single.prototype.setResolve = function(res){
  if(res === false){
    this.callfun = false;
  }else {
    this.callfun = true;
  }
}
var oneRequest = new single();

  

 

以上是关于JS解决页面多次,重复请求 的2个方法的主要内容,如果未能解决你的问题,请参考以下文章

需要一种有效的方法来避免使用 Laravel 5 重复代码片段

关于多次重复网络请求问题

有没有办法将2个非常相似的代码片段组合成一个函数并重复?

防止重复发送Ajax请求问题

百度统计发现“静态页参数 在静态页面上使用动态参数,会造成spider多次和重复抓取”的问题如何解决

微信浏览器重复请求