防抖函数:
const delay = (function(){
let timer = 0;
return function(callback, ms) {
clearTimeout(timer);
timer = setTimeout(callback, ms)
}
})()
表单中使用防抖函数,代码如下:
<template>
<div>
<el-form :model="form" :rules="rules" ref="form">
<el-form-item label="测试" prop="name">
<el-input v-model="form.name"></el-input>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
data() {
let validateName = (rule, value, callback) => {
if(value) {
// 调用防抖函数,添加需要的时间
delay(()=> {
// 处理逻辑
},2000)
}
}
// 防抖函数
const delay = (function(){
let timer = 0;
return function(callback, ms) {
clearTimeout(timer);
timer = setTimeout(callback, ms)
}
})()
return {
form: {
name: ''
},
rules: {
name: [{
required: true, validator: validateName, trigger: ['blur', 'change']
}]
}
}
}
}
</script>