JavaScript 防抖代码
时间: 2023-03-27 14:03:42 浏览: 226
可以使用以下代码实现 JavaScript 防抖:
function debounce(func, delay) {
let timer = null;
return function() {
const context = this;
const args = arguments;
clearTimeout(timer);
timer = setTimeout(function() {
func.apply(context, args);
}, delay);
}
}
其中,func 是需要执行的函数,delay 是延迟时间。这段代码的作用是在 delay 时间内,如果有多次触发该函数,只执行最后一次触发的函数。
相关问题
javascript防抖
JavaScript 防抖是一种技术,用于限制在特定时间内连续触发的事件被多次执行。例如,当用户在输入框中连续输入时,可能会触发多次 keyup 事件。如果我们在 keyup 事件中执行了一些复杂的操作,则可能会导致性能问题。这时,我们可以使用防抖来解决这个问题。
防抖的原理是在事件触发后,延迟一定的时间执行相应的操作,如果在延迟的时间内又触发了相同的事件,则取消之前延迟的执行,重新开始计时。这样,在短时间内连续触发的事件,只会执行一次。
下面是一个简单的防抖函数的实现:
```
function debounce(fn, delay) {
let timer = null;
return function() {
clearTimeout(timer);
timer = setTimeout(() => {
fn.apply(this, arguments);
}, delay);
}
}
```
使用方法:
```
document.querySelector('input').addEventListener('keyup', debounce(function() {
console.log('do something');
}, 1000));
```
在上面的代码中,我们将 debounce 函数用作事件监听器。每当用户在输入框中输入时,就会触发 keyup 事件。debounce 函数会延迟 1 秒(即 delay 参数的值)执行回调函数。如果在 1 秒内再次触发 keyup 事件,则取消之前的延
手写javaScript防抖函数
当用户在短时间内频繁触发某个事件时,防抖函数可以将多次触发的事件合并成一次,并在一定时间后执行一次。以下是一个手写的 JavaScript 防抖函数的示例代码:
```javascript
function debounce(func, delay) {
let timer = null;
return function() {
const context = this;
const args = arguments;
clearTimeout(timer);
timer = setTimeout(function() {
func.apply(context, args);
}, delay);
};
}
```
其中,`func` 是需要执行的函数,`delay` 是防抖的时间间隔。在防抖函数内部,使用 `setTimeout` 来延迟执行 `func` 函数,并在每次触发事件时清除上一次的延时器。最后,返回一个新的函数,用于替代原来的事件处理函数。
阅读全文