不要使用el-input的@input事件,使用这个事件,使用防抖无效。上实际代码,如下:

<template>
// 其他代码省略
 <el-input suffix-icon="el-icon-search" v-model="page.searchCode" clearable></el-input>
</template>
<script>
	data() {
	    return {
	      timer: '',
	      page:{
	      	searchCode:''//搜索框绑定值
	      }
	    }
	  },
	  watch: {
	    'page.searchCode': {
	      deep: true,
	      handler(newVal, oldVal) {
	        // if (newVal.trim().length !== 0) {
	         //this.getList是methods中延迟后调用的方法 延迟500ms
	        this.debounce(this.getList, 500) 
	        // }
	      }
	    }
	  },
	  methods: {
	    //防抖
	    debounce(fn, wait) {
	      if (this.timer !== null) {
	        clearTimeout(this.timer)
	      }
	      this.timer = setTimeout(fn, wait)
	    }
	  },
	  getList(){}//请求写在这里面即可
	}
</script>

GitHub 加速计划 / eleme / element
54.06 K
14.63 K
下载
A Vue.js 2.0 UI Toolkit for Web
最近提交(Master分支:2 个月前 )
c345bb45 7 个月前
a07f3a59 * Update transition.md * Update table.md * Update transition.md * Update table.md * Update transition.md * Update table.md * Update table.md * Update transition.md * Update popover.md 7 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐