【JS进阶】防抖与节流

这篇具有很好参考价值的文章主要介绍了【JS进阶】防抖与节流。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

防抖与节流

1.防抖

1.1 为什么要防抖?

在项目中,有的操作是高频触发的,但是其实触发一次就好了,比如我们短时间内多次缩放页面,那么我们不应该每次缩放都去执行操作,应该只做一次就好。再比如说监听输入框的输入,不应该每次都去触发监听,应该是用户完成一段输入后再进行触发。

所以,防抖就是防止抖动,避免事件的重复触发

思路:等待用户高频操作完成后,再完成操作。

1.2 基础防抖如何实现?

【JS进阶】防抖与节流,JS进阶,javascript,前端

基础设计思路:事件触发后,开启一个定时器,当该定时器到时间时,触发操作;而如果事件在该定时器限定的时间内再次触发,则清除当前定时器,并再次开启一个新的定时器。

代码如下:

// fn --- 要执行的操作,delay --- 延迟时间,在该时间内用户没有再次触发则执行操作
function debounce(fn, delay){
    // timer --- 定时器的名称,用于清除定时器
	let timer = null;
	return function(arguments){
         // 实际进行防抖的部分
         // 如果再次触发,首先清除上一次的定时器
		clearTimeout(timer);
         // 创建一个新定时器并记录名称
		timer = setTimeout(()=> {
             // 用apply方法执行目标函数
			fn.apply(this, arguments);
		}, delay)
	}
}

实际上,可以通过下面这张图来理解基础的防抖:

【JS进阶】防抖与节流,JS进阶,javascript,前端

2.节流

2.1 为什么要节流?

基础的防抖存在一个问题,事件会一直等到用户完成操作后一段时间在操作,如果一直操作,会一直不触发。比如说是一个按钮,点击就发送请求,如果一直点,那么请求就会一直发布出去。这里正确的思路应该是第一次点击就发送,然后上一个请求回来后,才能再发,即节流。

节流就是减少流量,将频繁触发的事件减少,并每隔一段时间执行。即,控制事件触发的频率

思路:某个操作希望上一次的完成后再进行下一次,或者希望隔一段时间触发一次

2.2 如何实现基础节流?

【JS进阶】防抖与节流,JS进阶,javascript,前端

基础设计思路:我们可以设计一种类似控制阀门一样定期开放的函数,事件触发时让函数执行一次,然后关闭这个阀门,过了一段时间后再将这个阀门打开,再次触发事件。

代码如下:

// fn --- 要执行的操作,delay --- 延迟时间,在该时间内操作最多只会执行一次
function throttle(fn, delay){
    // 阀门是否开启
	let valid = true;
	return function(arguments){
		if(valid) { 
             //如果阀门已经打开,就继续往下,设定定时器,指明在一定延迟时间后执行一次操作
             // 此时已经确定会执行一次操作,因此关闭阀门
			valid = false;
			setTimeout(()=> {
				fn.apply(this, arguments);//定时器结束后执行
				valid = true;//执行完成后打开阀门
			}, delay)
		}
	}
}

实际上,可以通过下面这张图来理解基础的节流:

【JS进阶】防抖与节流,JS进阶,javascript,前端

3.防抖节流的应用场景、联系以及区别

防抖
  1. search搜索联想,用户在不断输入值时,用防抖来节约请求资源
  2. window触发resize的时候,不断的调整浏览器窗口大小会不断的触发这个事件,用防抖来让其只触发一次
节流
  1. 鼠标不断点击触发,mousedown(单位时间内只触发一次)
  2. 监听滚动事件,比如是否滑到底部自动加载更多
联系与区别

防抖节流的共同点在于:都是为了阻止操作高频触发,从而浪费性能。

两者的不同点在于:

  • 防抖是触发高频事件后n秒内函数只会执行一次,如果n秒内高频事件再次被触发,则重新计时。适用于可以多次触发但触发只生效最后一次的场景,可能会出现操作始终不执行的情况。
  • 节流则不同,事件高频触发,无论触发多少次,在一定时间内只会执行一次,即定期执行。相比于防抖,节流的响应更加平滑,不会出现始终不执行操作的情况!

4.防抖与节流的优化

对于上面的基础防抖与节流的方法,主要有两个可以优化的方面:

  1. 复用性优化:对于实际项目中,我们不可能在每次需要进行防抖节流的时候,都重新写一遍代码,因此,我们需要将防抖节流的方法封装为内部API提高复用性!
  2. 功能方面的优化
    1. 防抖:添加立即执行选项解决可能始终不执行的问题;延迟防抖,解决高频设定定时器的问题。
    2. 节流:可能需要点击后立即执行等等。
立即执行

在某些业务场景中,使用防抖节流时,基础的防抖节流可能会导致响应时间变长,这就会影响到用户的使用体验,因此,需要在触发事件的时候,立即执行处理函数,但后续也能起到防抖节流的作用。

立即执行的防抖和节流,其原理是一致的,即:添加一个计数器或立即执行的标识

实现如下:

// 防抖
export const debounce = (fun , wait=1000) => {
  let timeout = null
  let count = 0
  return function(){
    let _this = this
    let arg = arguments
    if(timeout){//如果存在定时器就清空
      clearTimeout(timeout)
    }
    if (!count) {
      // 第一次点击时立即执行
      count++
      fun.apply(_this, arg)
      timeout = setTimeout(() => {
        count = 0
      }, wait)
    } else {
      count++
      timeout = setTimeout(() => {
        fun.apply(_this, arg)
        count = 0
      }, wait)
    }
  }
}

// 节流
export const throttled = (fun, wait=1000, immediate) => {
  let preTime = 0;
  let timerId;
  return function() {
    let _this = this;
    let args = arguments;
    if(immediate) { // immediate 为true 时立即执行
      let nowTime = Date.now();
      if(nowTime - preTime > wait) {
        fun.apply(_this, args);
        preTime = nowTime;
      }
    } else {
      if(!timerId) {
        timerId = setTimeout(function() {
          fun.apply(_this, args);
          timerId = null;
        }, wait);
      }
    }
  }
}
其他优化

在不同的业务场景中,对于防抖节流也有不同的需求,如果单纯地为了每一个场景编写防抖节流函数,是相当费事且麻烦的工作,因此,不如使用别人封装好的库。

参考:http://t.csdn.cn/RVzMK

最终解决方案:

underscore.js 库中的 _.throttle()_.debounce() — 参考https://www.likecs.com/show-307738657.html文章来源地址https://www.toymoban.com/news/detail-703460.html

到了这里,关于【JS进阶】防抖与节流的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 前端面试题-js-new关键字-this指向-js事件流-防抖节流

    1.创建一个简单的空对象 2.原型的绑定,确定对象O的原型链 3.绑定this对象为O,传入参数;执行Person构造函数,进行属性和方法的赋值操作 4.返回结果 普通函数的this指向 函数的this指向有一个基本的原则,谁调用的函数,函数的this就指向谁,否则指向全局 箭头函数的this指向

    2024年01月25日
    浏览(39)
  • JS—节流与防抖

    一、js防抖和节流 在进行窗口的resize、scroll、输出框内容校验等操纵的时候,如果事件处理函数调用的频率无限制,会加重浏览器的负担,导致用户体验非常之差。那么为了前端性能的优化也为了用户更好的体验,就可以采用防抖(debounce)和节流(throttle)的方式来到达这种

    2023年04月08日
    浏览(31)
  • javascript常见100问|前端基础知识|问ajax-fetch-axios-区别请用 XMLHttpRequestfetch 实现 ajax节流和防抖px em rem vw/箭头函数的缺点

    HTML CSS JS HTTP 等基础知识是前端面试的第一步,基础知识不过关将直接被拒。本章将通过多个面试题,讲解前端常考的基础知识面试题,同时复习一些重要的知识点。 扎实的前端基础知识,是作为前端工程师的根本。基础知识能保证最基本的使用,即招聘进来能干活,能产出

    2024年04月27日
    浏览(39)
  • 前端刷题-防抖节流

    在实际的开发过程中,一般会使用lodash自有的debounce函数和throttle函数对所要防抖/节流的函数进行包裹。例如

    2024年02月10日
    浏览(29)
  • 前端优化 ----防抖 节流

    如果一个事件在短时间内连续触发,则只去执行最后一次。 控制频率 实现方式:每次触发事件时设置一个延迟调用方法,并且取消之前的延时调用方法 缺点:如果事件在规定的时间间隔内被不断的触发,则调用方法会被不断的延迟 使一个函数在固定时间内只执行一次。控制

    2024年02月04日
    浏览(28)
  • 【前端】防抖和节流原理+实现

    防抖(Debounce)和节流(Throttle)都是用于控制函数执行频率的机制,它们在处理高频触发的事件时非常有用。 防抖的原理是在事件被触发后,等待一段时间(例如200毫秒)来执行函数,如果在等待时间内事件被再次触发,则重新计时。这样可以避免在短时间内多次触发事件

    2024年04月16日
    浏览(24)
  • 节流防抖:提升前端性能的秘密武器(上)

    🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入

    2024年02月04日
    浏览(32)
  • 【js】防抖和节流的使用场景和区别:

    一、防抖 (多次触发 只执行最后一次) 作用: 高频率触发的事件,在指定的单位时间内,只响应最后一次,如果在指定的时间内再次触发,则重新计算时间 防抖类似于英雄联盟回城6秒,如果回城中被打断,再次回城需要再等6秒 二、节流 (规定时间内 只触发一次) 作用:

    2024年02月10日
    浏览(25)
  • js实现防抖(debounce)与节流(throttle)

    一句话概括:防抖是给定一个时间周期,如果触发事件的周期小于该时间(也就是触发过快),则不会触发事件。 举个例子:我给定的时间周期是1s,如果我在触发第一次事件后1s内触发该事件,则重新开始计时,直到触发周期大于1s才会执行事件的方法。 一句话概括:节流

    2023年04月23日
    浏览(25)
  • 前端解决按钮重复提交数据问题(节流和防抖)

    🍿*★,°*:.☆( ̄▽ ̄)/$:*.°★* 🍿 🍟欢迎来到前端初见的博文,本文主要讲解在工作解决按钮重复提交数据问题(节流和防抖) 👨‍🔧 个人主页 : 前端初见 🥞喜欢的朋友可以关注一下,下次更新不迷路🥞 当我们在页面进行点点点的操作时,很可能遇到点击两次的行为,

    2024年02月09日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包