js实现ajax搜索的有趣逻辑




要实现的功能很简单,输入时去请求数据,删到空时显示热门学校。

一开始我的想法挺简单

$("input").on("input", function() {
	if (len == 0) { //len即搜索框中文字的长度
		hotSchoolRender(); //热门学校渲染
	} else {
		// ajax请求
		ajaxObj = $.ajax({
			type: 'POST',
			url: url,
			data: data,
			dataType: 'json',
			success: function(result) {
				searchSchoolRender(result); //对搜索到得学校进行渲染
			},
			error: function() {
				...
			}
		})
	}
})

这样输入慢点、删慢点没关系,但是如果是 打一个字、立刻删除,那就出问题了。

因为此时ajax还挂起在,而hotSchool已经被渲染出来了,等到ajax完成之后,又会做searchSchool的渲染,这样就事与愿违。


那怎么样避免这种情况呢?

中断请求

var ajaxObj;
$("input").on("input",function(){
	if(len == 0){	//len即搜索框中文字的长度
		ajaxObj.abort();	//中断上一个ajax请求
		hotSchoolRender();	//热门学校渲染
	}else{
		// ajax请求
		ajaxObj.abort();	//中断上一个ajax请求
		ajaxObj = $.ajax({
			type: 'POST',
			url: url,
			data: data,
			dataType: 'json',
			success: function(result) {
				searchSchoolRender(result);	//对搜索到得学校进行渲染
			},
			error: function(){
				...
			}
		})
	}
})

似乎搜索逻辑到此就完整了,然后兴高采烈的狂输一顿,哇擦,又出问题了~

请求过于猛烈,服务器招架不住了~

那这个时候怎么办呢?


延迟ajax请求

var ajaxObj;
var timeout = 0;
$("input").on("input",function(){
	if(len == 0){	//len即搜索框中文字的长度
		ajaxObj.abort();	//中断上一个ajax请求
		hotSchoolRender();	//热门学校渲染
	}else{
		clearTimeout(timeout);	//清除上次的计时器
		timeout = setTimeout(function(){
			// ajax请求
		ajaxObj.abort();	//中断上一个ajax请求
		ajaxObj = $.ajax({
			type: 'POST',
			url: url,
			data: data,
			dataType: 'json',
			success: function(result) {
				searchSchoolRender(result);	//对搜索到得学校进行渲染
			},
			error: function(){
				...
			}
		})
		},500);
	}
})


至于时间的话,自己DIY咯,END~

PS:主要讲思路,代码有误请见谅。I'm fresh man,请各位多指教 大笑


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值