js防抖与节流的封装

防抖

防抖就是指触发事件后在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执行时间。(在固定时间内,将多次操作变成一次。)

在开发中,经常遇到当在输入框中输入内容,就会向后台发送请求。这时候就需要前端做一个优化。

首先在页面创建一个输入框,模拟一下当输入框值发生改变,就会发送请求。

<body>
<input placeholder="请输入电话"/>

<script>
    // 第一步获取input元素,监听事件
    let lelInput = document.querySelector('input')
    lelInput.addEventListener('input', (e) => {
        console.log('发起请求了')
    })
</script>
</body>

 当我们值发生变化,就会发送一次请求。所以我们需要封装一个防抖函数,进行优化。

防抖的思路:是将多次操作变成一次,那我们可以利用clearInterval和setTimeout。当触发事件的时候,把延时器清除,然后再设置样式器。

    // 防抖函数
    function antishake(fu,time) {
        let timeOut = null;
        return function() {
            if(timeOut) clearInterval(timeOut)
            timeOut = setTimeout(fu,time)
        }
    }

完整代码:

<body>
<input placeholder="请输入电话"/>

<script>
    // 第一步获取input元素,监听事件
    let lelInput = document.querySelector('input')
    lelInput.addEventListener('input',antishake(myAxios,2000))

    // 防抖函数
    function antishake(fu,time) {
        let timeOut = null;
        return function() {
            if(timeOut) clearInterval(timeOut)
            timeOut = setTimeout(fu,time)
        }
    }

    //请求操作
    function myAxios() {
        console.log('发起请求了')
    }

</script>
</body>

节流

节流就是指连续触发事件但是在 n 秒中只执行一次函数。节流会稀释函数的执行频率。(一定时间内多个事件合为一个。)

应用场景:1.提交表单  2.高频监听事件

防抖的思路:每次触发事件,调用延时器,执行完清空延时器。当下一次触发事件,如果延时器执行完成,则继续执行。这样就实现了n秒内只执行一次。

    // 节流函数
    function throttle(fu,time) {
        let timeOut = null;
        return function() {
            if(!timeOut) {
                timeOut = setTimeout(()=>{
                    fu();
                    timeOut = null;
                },time)
            }
        }
    }

完整代码:

<body>
    <div class="box" style="width: 300px;height: 300px;background-color:red;">

    </div>

<script>
    // 第一步获取box元素,监听事件
    let box = document.querySelector('.box')
    box.addEventListener('touchmove',throttle(myAxios,2000))

    // 节流函数
    function throttle(fu,time) {
        let timeOut = null;
        return function() {
            if(!timeOut) {
                timeOut = setTimeout(()=>{
                    fu();
                    timeOut = null;
                },time)
            }
        }
    }

    //请求操作
    function myAxios() {
        console.log('发起请求了')
    }
</script>
</body>

以上就是js防抖与节流。

防抖节流是两种常用的函数优化技术,可以用来限制函数的执行频率,提高性能和用户体验。 防抖函数的作用是在短时间内连续触发同一事件时,只执行最后一次操作,而忽略之前的操作。可以用于处理频繁触发的事件,比如窗口大小改变、输入框输入等。 下面是一个简单的防抖函数封装示例: ```javascript function debounce(func, delay) { let timer = null; return function(...args) { clearTimeout(timer); timer = setTimeout(() => { func.apply(this, args); }, delay); }; } ``` 使用方式示例: ```javascript function handleInput() { // 处理输入事件 } const debouncedHandleInput = debounce(handleInput, 300); // 创建防抖函数 inputElement.addEventListener('input', debouncedHandleInput); // 绑定防抖函数到输入框的输入事件 ``` 节流函数的作用是在一定时间间隔内只执行一次操作,可以用于处理高频率触发的事件,比如滚动事件、鼠标移动事件等。 下面是一个简单的节流函数封装示例: ```javascript function throttle(func, delay) { let timer = null; return function(...args) { if (timer) return; timer = setTimeout(() => { func.apply(this, args); timer = null; }, delay); }; } ``` 使用方式示例: ```javascript function handleScroll() { // 处理滚动事件 } const throttledHandleScroll = throttle(handleScroll, 300); // 创建节流函数 window.addEventListener('scroll', throttledHandleScroll); // 绑定节流函数到窗口的滚动事件 ``` 以上是基本的防抖节流函数封装示例,可以根据实际需求进行调整和扩展。希望能对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值