代码拉取完成,页面将自动刷新
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/npm/underscore@1.13.4/underscore-umd-min.js"></script>
</head>
<body>
<!--
防抖: 将多次执行函数变成最后⼀次执行 等待固定时间还没有事件触发时执行的函数
应用场景:
按钮的点击
屏幕滚动时的复杂计算
输⼊框输⼊时进行搜索
用户缩放浏览器的resize事件
简单的防抖函数实现:
-->
<input type="text">
<script>
function mldebounce(fn, delay) {
// 用于记录上一次事件触发的timer
let timer = null;
const _debounce = () => {
if (timer) clearTimeout(timer)
timer = setTimeout(() => {
fn();
timer = null;
}, delay)
}
return _debounce;
}
</script>
<script>
// 1.获取input元素
const inputEl = document.querySelector("input")
// 2.监听input元素的输入
// let counter = 1;
// inputEl.oninput = function () {
// console.log(`发送网络请求${counter++}`);
// }
// 做防抖处理
// let counter = 1;
// inputEl.oninput = _.debounce(function () {
// console.log(`发送网络请求${counter++}`);
// }, 3000)
// 调用自己的debounce
let counter = 1;
inputEl.oninput = mldebounce(function () {
console.log(`发送网络请求${counter++}`);
}, 3000)
</script>
</body>
</html>
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。