什么是函数防抖?

在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时

实现很简单,大体就是设置一个变量来记录定时器,每次触发事件的时候就看定时器是否存在,如果存在清除一下,然后重新开启一个定时器。时间到了,定时器就执行了。

由于很好理解,直接上代码:

// index.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Type Script in Action</title>
    <script src="/src/libs/global-lib.js"></script>
</head>
<body>
    <div class="app"></div>
</body>
</html>
// 脚本文件-使用了Jquery

import $ from "jquery";
$(".app").eq(0).css("width", "200px");
$(".app").eq(0).css("height", "200px");
$(".app").eq(0).css("background", "#ff6600");

$(".app").eq(0).on("mousemove", mouseMoveEvent);

let moveWatcher: null | number = null;

interface nodeEvent {
    target: {
        nodeName: string;
    };
    [key: string]: any;
}

function mouseMoveEvent(event: nodeEvent): void {
    if (moveWatcher) {
        clearTimeout(moveWatcher);
        moveWatcher = null;
    }

    moveWatcher = window.setTimeout(() => {
        console.log(event.target.nodeName);
    }, 1000);
}

到此结束,睡觉