zoukankan      html  css  js  c++  java
  • JS系列1---节流,去抖(防抖)应用场景:intput请求优化,页面监听

      在项目开发过程中经常遇到在input的change事件中发起请求,将用户最新输入的字符作为data传给后台,但是如果用户的输入频率过高,或者用户输入的字符还未拼成一个完整的字词,这时候发起请求会浪费网络资源,使页面卡顿。

      这时候我们就用到了函数去抖(debounce)函数节流(throttle),首先来看一下概念:

      1,函数去抖(又称防抖)

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

      未优化前代码demo:

            <input id="debounceTest" />
            <script>
                function ajax(value) {
                  console.log(value+'-----------发起ajax请求')
                }
                
                let inputa = document.getElementById('debounceTest')
                
                inputa.addEventListener('keyup', function (e) {
                    ajax(e.target.value)
                })
            </script>

      效果图:

      

      从页面中可以看到,只要触发了keyup时间,页面就会发起请求,不管用户是否输入了一个完整的字符,这样对网络资源十分浪费,在移动端甚至可能造成用户体验不流畅,系统卡顿,所以我们来对代码进行优化,如下:

    优化后代码demo:

    function ajax(content) {
      console.log(content+'---------------ajax请求')
    }
    
    function debounce(fun, delay) {
        return function (args) {
            let that = this
            let _args = args
            clearTimeout(fun.id)
            fun.id = setTimeout(function () {
                fun.call(that, _args)
            }, delay)
        }
    }
        
    let inputb = document.getElementById('debounce')
    
    let debounceAjax = debounce(ajax, 500)
    
    inputb.addEventListener('keyup', function (e) {
            debounceAjax(e.target.value)
        })

      页面效果:

      

      可以看出,当用户一直在输入时,页面不会发起请求,当用户的上次输入与下次输入有一定时间间隔时,页面才会发起请求。

    同样的问题还有另一种解决方法:

    2,函数节流(throttle)

         规定在一个单位时间内,只能触发一次函数。如果这个单位时间内触发多次函数,只有一次生效。

     还是上边的例子,这次用节流的方法实现

    节流后的代码demo:

    function throttle(fun, delay) {
            let last, deferTimer
            return function (args) {
                let that = this
                let _args = arguments
                let now = +new Date()
                if (last && now < last + delay) {
                    clearTimeout(deferTimer)
                    deferTimer = setTimeout(function () {
                        last = now
                        fun.apply(that, _args)
                    }, delay)
                }else {
                    last = now
                    fun.apply(that,_args)
                }
            }
        }
    
        let throttleAjax = throttle(ajax, 1000)
    
        let inputc = document.getElementById('throttle')
        inputc.addEventListener('keyup', function(e) {
            throttleAjax(e.target.value)
        })

    页面效果:

      可以看出,不管用户的输入速度是多少,页面总是以恒定的间隔向后台发起请求。

      函数节流还可以应用于其他事件,比如mouse移动事件,页面滚动事件,resize事件等能高频次触发的事件中。

    函数节流和去抖都是为了解决事件触发频率过高的问题,但是使用了不同的原理

    节流是总是以固定的间隔发起请求,对高频率事件做做次数限制。去抖是固定时间段内只发送一次请求。对高频率事件做做次数限制

      以上为节流去抖的全部内部,如有错误还望指正。

  • 相关阅读:
    BN
    框架中的DDP和buffer
    深度学习框架中的并行
    Transformer
    自监督表示学习Paper
    半监督学习paper阅读
    目标检测经典paper
    STM32_从SystemInit、__main到main() 已修正
    STM32启动代码分析及其汇编学习-ARM
    Rust 及其包管理Cargo的安装使用
  • 原文地址:https://www.cnblogs.com/zzzzyy/p/11230303.html
Copyright © 2011-2022 走看看