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 重复代码片段