vue 实时搜索 防抖功能

最近在做实时搜索功能时,被要求使用防抖函数,就自己手写一个,已用于大型项目中

<template>
   <el-input placeholder="请搜索关键字" @input="inputHandle" v-model="input4">
      <i slot="prefix" class="el-input__icon el-icon-search"></i>
   </el-input>
</template>
export default{
	data(){
		timeId: undefined,
		isLoading: false,
		input4: ''
	},
	methods:{
		inputHandle(val){
			this.input4 = val
			/*以下为防抖代码*/
		    if (!this.timeId && !this.isLoading) {
		      this.guidanceTailList()
		    }
		    if (this.timeId) {
		      clearTimeout(this.timeId)
		    }
		    this.timeId = setTimeout(() => {
		      this.timeId = undefined
		      clearTimeout(this.timeId)
		      this.guidanceTailList()
		    }, 2500)
		    /*以上为防抖代码*/
		},
		guidanceTailList(){
			this.isLoading=true
			...
			...省略ajax请求
			...
			this.isLoading=false
		}
	}
}

总结–:自己平常没事的时候就会看看基础API,巩固一下基础,这样,在封装公共组件或者公共方法时,就不会手忙脚乱,毫无头绪了! 现在的努力,总会在将来的某个不经意的时间收到回报的,加油!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值