为了账号安全,请及时绑定邮箱和手机立即绑定

vue做一个搜索,每次按下键盘都会请求一次?

vue做一个搜索,每次按下键盘都会请求一次?

Smart猫小萌 2019-03-14 17:15:45
一个类似微信的搜索,没有“搜索”按钮,就一个input框。<input @keyup="load_list($event)">现在一个问题:输入“ABCD”向后台发送了4次请求A一次B一次C一次D一次于是我加了定时器,1秒后发送请求:输入“ABCD”向后台发送了4次请求ABCD一次ABCD一次ABCD一次ABCD一次我要疯了,有好的解决方法么?
查看完整描述

9 回答

?
米脂

TA贡献1836条经验 获得超3个赞

写定时器是完全可以实现的 每次输入的时候都要先清除定时器 然后再新开一个定时器 什么时候时间到了 什么时候才会触发。example:


全局:let timer = null;

method:{

    load_list(){

        clearInterval(timer);

        timer = setInterval(()=>{

            Ajax();

        }, 1000)

    }

}

try one try.


查看完整回答
反对 回复 2019-04-11
?
德玛西亚99

TA贡献1770条经验 获得超3个赞

你需要防抖(debounce)函数


查看完整回答
反对 回复 2019-04-11
?
牛魔王的故事

TA贡献1830条经验 获得超3个赞

比较简单稳定的方法:引入 lodash
如果想控制输入后函数执行的频率,使用 lodash 中的 debounce 模块。
参考链接

查看完整回答
反对 回复 2019-04-11
?
开心每一天1111

TA贡献1836条经验 获得超13个赞

跟vue没关系,你用的keyup事件,就是每次按键了抬起就触发一次,你可以写个定时器,没问题,但是要用setinterval,var aa = setinterval(); 设置一个输入时限,入过在时限内,就clearInterval(aa),然后再加setinterval.


查看完整回答
反对 回复 2019-04-11
?
犯罪嫌疑人X

TA贡献2080条经验 获得超4个赞

输入之后设置个定时器来控制请求,如果又监听到键盘的输入操作,取消定时器,如果没有就请求


查看完整回答
反对 回复 2019-04-11
?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

用@input事件即可。改动最小


查看完整回答
反对 回复 2019-04-11
?
白板的微信

TA贡献1883条经验 获得超3个赞

  • 推荐@input事件

  • 首先你要搞清楚你搜索的规则(字符串length..)达到这个规则再进行请求


查看完整回答
反对 回复 2019-04-11
  • 9 回答
  • 0 关注
  • 1121 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号