vue 实现防抖

1.首先新建一个debounce.js代码如下

const debounce=function(fn, delay){
     
	let timer = null
	return function(){
     
		let content = this;
		let args = arguments;
		if(timer){
     
			clearTimeout(timer)
		}
		timer = setTimeout(()=>{
     
			fn.apply(content,args)
		}, delay)
	}
}
export default debounce

2.在需要防抖的vue文件中引入debounce,内容如下;这是一个输入框的500ms的防抖

<template>
    <div class="main">
        <el-input v-model="input" @change="changeSeletc" placeholder="请输入内容"></el-input>
    </div>
</template>
<script>
    import debounce from "../utils/debounce"
    export default {
     
        name: "alarm",
        data(){
     
            return{
     
                input: ''
            }
        },
        methods:{
     
            changeSeletc:debounce(function () {
     
                console.log(this.input)
            },500),
        }
    }
</script>
<style scoped>
</style>

3.效果如下图

vue 实现防抖_第1张图片

你可能感兴趣的:(vue,js,elementui)