【面试题】面试官:说说你对js中的 防抖 和 节流 的理解

news2025/4/6 5:31:40

 前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

 表妹一键制作自己的五星红旗国庆头像,超好看

前言

看到这个题目我想肯定会有人说:不会吧,都3202年了,还有人发防抖和节流的文章嘛🤣?确实,在现在的实际项目中防抖和节流对我们并不陌生,甚至经常使用,但是对它们的原理和适用的场景可能并没有那么熟悉,甚至还会搞混,那么通过本篇文章加大你对防抖和节流的认识!

话不多说,直接上链接!,不对不对,是上结论哈哈哈哈

函数节流是指一定时间内函数只执行一次。比如人的眨眼睛,就是一定时间内眨一次。 函数防抖是指频繁触发的情况下,只有足够的空间时间,才执行代码一次。比如坐公交,就是一定时间内,如果有人陆续刷卡上车,司机就不会开车。只有别人没刷卡了,司机才开车。

一、JavaScript防抖函数

1、JavaScript防抖函数详解

防抖函数是JavaScript中常用的一种函数优化技术,可以有效减少一些高频率触发的事件所带来的性能问题。本文将详细介绍JavaScript防抖函数的实现原理、应用场景和使用方法。

2、防抖函数的实现原理

防抖函数的实现原理非常简单,就是在一定时间内只执行最后一次触发的事件,忽略之前触发的所有事件。具体实现方法如下:

1、设置一个定时器,当触发事件时,如果定时器存在,则清除定时器。

2、重新设置一个定时器,延迟一定时间后执行事件。

3、如果在延迟时间内再次触发事件,则重复1和2的步骤。

4、如果延迟时间到了,执行事件。

3、防抖函数的应用场景

防抖函数适用于一些高频率触发的事件,比如:

1、输入框实时搜索,避免频繁请求后端接口。

2、浏览器窗口resize事件,避免频繁触发DOM操作。

3、滚动条滚动事件,避免频繁更新DOM。

4、按钮点击事件,避免重复提交表单。

4、手写实现防抖函数

可以通过手写实现防抖函数,代码如下:

//JavaScript防抖核心代码
// fn: 点击按钮要执行的函数
// delay: 延迟时间
<script>
    function debounce(fn, delay) {
      let timer = null;
      return function() {
        clearTimeout(timer);
        timer = setTimeout(() => {
          fn.apply(this, arguments);
        }, delay);
      }
    }
</script>

这样用户在频繁点击按钮时,就可以执行延迟操作,防止函数多次调用,完成防抖功能;

手写实现防抖函数注意事项:

(1)、debounce函数不能直接调用fn函数,因为按钮绑定的事件函数是直接调用的,所以使用返回函数,否则函数会立即执行;

(2)、每次点击先清除延时操作,clearTimeout不能清除一个没有定义的变量名,所以需要先定义一个变量timer用来清除和定义延时操作;

(3)、在函数外层定义timer,函数内部方便使用,让这些独立的执行函数有联系;

(4)、调用函数fn,容易忽略this指向,需要将this指向调用者。

5、Lodash库实现防抖函数

Lodash是一个非常流行的JavaScript工具库,它提供了许多方便的函数,包括防抖函数。可以通过Lodash库来实现防抖函数,代码如下:

npm install -save lodash    /    npm install lodash 
 
import debounce from 'lodash/debounce';
 
function handleInput(event) {
  // 在250ms内只执行最后一次输入
}
 
const debouncedInput = debounce(handleInput, 250);
input.addEventListener('input', debouncedInput);

6、防抖函数的注意事项

1、防抖函数的延迟时间需要根据实际情况设置,设置过短可能会导致事件被频繁触发,设置过长可能会影响用户体验。

2、防抖函数返回的是一个新函数,所以需要将其赋值给原来的函数。

3、防抖函数的this指向需要明确,可以使用箭头函数或者bind方法来解决。

二、JavaScript节流函数

1、什么是JavaScript节流函数

JavaScript节流函数是一种优化技术,它可以限制函数的执行频率,从而避免在短时间内重复执行同一个函数。节流函数通常用于优化用户输入的响应、滚动事件、窗口调整等操作。当用户频繁地触发这些事件时,节流函数可以将这些事件的处理推迟到一段时间后再执行,从而避免过度的计算和渲染,提高网页的性能和用户体验。

2、JavaScript节流函数的实现原理

解析:JavaScript节流函数的实现原理很简单,它通过使用定时器来控制函数的执行频率。当用户触发一个事件时,节流函数会检查前一个事件的处理是否已经完成,如果已经完成,则立即执行当前事件的处理;否则,将当前事件的处理推迟到一段时间后再执行。这样可以避免在短时间内重复执行同一个函数,从而提高网页的性能和用户体验。

3、JavaScript节流函数的应用场景

JavaScript节流函数可以应用于很多场景,例如:

用户输入的响应:当用户在输入框中输入内容时,节流函数可以将输入的处理推迟到一段时间后再执行,从而避免在用户输入时频繁地计算和渲染。

滚动事件的处理:当用户滚动页面时,节流函数可以将滚动事件的处理推迟到一段时间后再执行,从而避免过度的计算和渲染。比如图片的懒加载

窗口调整的处理:当用户调整窗口大小时,节流函数可以将窗口调整事件的处理推迟到一段时间后再执行,从而避免在用户调整窗口大小时频繁地计算和渲染。

4、JavaScript节流函数的实例

下面是一个简单的JavaScript节流函数的代码示例:

function throttle(fn, delay) {
  let timer = null;
  return function() {
    let context = this;
    let args = arguments;
    if (!timer) {
      timer = setTimeout(function() {
        fn.apply(context, args);
        timer = null;
      }, delay);
    }
  }
}

在这个代码示例中,throttle函数接受两个参数:要执行的函数fn和延迟时间delay,它返回一个函数,这个函数用来限制fn函数的执行频率

当用户触发事件时,这个函数会检查前一个事件的处理是否已经完成,如果已经完成,则立即执行当前事件的处理,否则,将当前事件的处理推迟到一段时间后再执行。这样可以避免在短时间内重复执行同一个函数,从而提高网页的性能和用户体验。这样,无论用户点击按钮多少次,该函数都只会在1秒内执行一次,避免了不必要的性能开销。

三、总结

1、防抖就是触发事件后n秒后才执行事件处理函数,如果在n秒内又触发了事件,就会重新计时

2、节流就是连续触发事件,在指定时间间隔内只会执行一次函数,节流会减少函数的执行频率。

 前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

 表妹一键制作自己的五星红旗国庆头像,超好看

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1043205.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

网络安全--IDS--入侵检测

1. 什么是IDS&#xff1f; IDS---入侵检测是防火墙的一个有力补充&#xff0c;形成防御闭环&#xff0c;可以及时、准确、全面的发现入侵弥补防火墙对应用层检查的缺失。对系统的运行状态进行监视&#xff0c;发现各种攻击企图、过程、结果&#xff0c;来保证系统资源的安全&a…

vue造轮子完整指南--npm组件包开发步骤

一、项目包文件的创建和初始化。 1. 新建项目包。 vue create <Project Name> //用于发布npm包的项目文件名 ps:一般选择自定义&#xff0c;然后不需要Vuex和Router&#xff0c;其他选项按自己实际情况选择安装即可。 2.修改原始src文件名、新增组件项目存放文件和修改…

大模型时代,如何找准AI发展新方向?TVP读书会与你共探

引言 随着 ChatGPT 掀起人工智能的发展狂潮&#xff0c;大模型时代悄然来临。大模型的出现让人们看到了人工智能在某些方面几乎接近人类智能的“威力”&#xff0c;也由此使人们产生了关于 AGI 的期盼与隐忧。其中&#xff0c;关于大模型是否是人工智能发展的拐点、科技从业者又…

使用chat GPT 生成一个js 生成天数的方法

function calculateDaysDifference(targetDateString) {const currentDate new Date();const targetDate new Date(targetDateString);// 计算毫秒差异const timeDifference targetDate - currentDate;// 计算天数差异&#xff0c;如果结果为负数&#xff0c;则设置为0const…

c语言结构体的内存对齐

前言&#xff1a; c语言中结构体的空间大小怎么算呢&#xff1f;就是把里面所有变量的字节大小全部加起来吗&#xff1f; 如果你这么想&#xff0c;说明你对结构体还不够了解&#xff0c;而要想知道结构体开辟空间的规则&#xff0c;那我们就必须先要知道内存对齐是什么。 接…

【链表】排序链表-力扣148题

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

Spring整合第三方框架-MyBatis原始操作代码

建议自己写一下 实体类&#xff0c;用于封装数据库数据 package com.example.pojo;import java.util.Date;public class Emp {private Integer id;private String username;private String password;private String name;private Integer gender;private String image;privat…

“ElementUI实现动态树和动态表格的综合应用“

目录 引言1. ElementUI树1.1 树的基本概念1.2 示例代码和效果展示 2. ElementUI实现动态表格2.1 表格的基本概念2.2 示例代码和效果展示 总结 引言 在前端开发中&#xff0c;动态树和动态表格是常见的功能需求。ElementUI是一套基于Vue.js的组件库&#xff0c;提供了丰富的UI组…

酒店预订小程序制作详细步骤解析

" 随着移动设备的普及和互联网技术的不断发展&#xff0c;小程序成为了一个备受关注的应用领域。特别是在酒店预订行业&#xff0c;小程序可以为酒店带来更多的客源和方便快捷的预订服务。下面是酒店预订小程序的制作详细步骤解析。 第一步&#xff1a;注册登录【乔拓云】…

消费增值模式:消费送积分,只涨不跌的商业模式!

大家好&#xff0c;我是微三云吴军&#xff0c;您们的专属私域电商管家&#xff0c;国庆将至&#xff0c;中秋将至&#xff0c;祝大家度过一个愉快的节假日。 我今天给大家带来的案例分析是我们一个客户的落地成功案例&#xff0c;一个月也做到了上百万&#xff0c;但是用户数…

24届近3年中国矿业大学自动化考研院校分析

所谓又专又精&#xff0c;专是指我们售后群团队上百人都是自动化研究生&#xff0c;精是指我们只做自动化这一门专业学科7年了&#xff0c;研究到极致&#xff01; &#x1f509;今天学姐给大家带来的是中国矿业大学控制考研分析 满满干货&#xff5e;还不快快点赞收藏 目录…

5+单细胞+脂质代谢+预后模型+实验

今天给同学们分享一篇5单细胞脂质代谢预后模型实验的生信文章“Single-cell transcriptome analysis reveals the metabolic changes and the prognostic value of malignant hepatocyte subpopulations and predict new therapeutic agents for hepatocellular carcinoma”&am…

【独家专访】“数网”同防筑牢屏障——新型电力系统网络安全保障体系需加快调整

随着全球数字化进程不断加快&#xff0c;在国际竞争和冲突中&#xff0c;网络战和数据战已然屡见不鲜。电力作为关系国计民生的关键行业&#xff0c;更成为网络攻击的重要对象。加强电力等关键信息基础设施的网络安全保障&#xff0c;是国家今后一段时期的重点工作。7月15日召开…

微信开发者工具appdata\local\微信开发者工具有啥用,能删掉吗?占用空间8G

你好这边 微信开发者工具\User Data 存储的都是一些用户开发者在工具的一些数据存储&#xff0c;不建议全部删除&#xff0c;这样可能你较常用的一些项目记录和缓存信息就会找不到&#xff0c;如果需要清理的话&#xff0c;可以考虑删除&#xff1a; WeappApplication 应用更新…

混淆技术研究笔记(一)常见工具介绍

混淆技术研究笔记包含多篇内容&#xff0c;记录了一次混淆的研究和应用的过程。 本文首发于 CSDN&#xff0c;随后会发布在 MyBatis 微信公众号&#xff0c;通过公众号可以免费阅读。 最近有一个 Java 的底层框架需要进行混淆&#xff08;从原始的 Java 项目改造为了 Maven 多模…

【挑战开发100个项目 | 2. C语言图书管理系统】

本项目是一个基于C语言的简单图书管理系统&#xff0c;用户可以通过命令行界面实现图书的添加、删除、修改、查找以及列出所有图书的功能。适用于初学者学习c语言&#xff0c;也适用于高校学生课程设计&#xff0c;毕业设计参考。 一&#xff0c;开发环境需求 操作系统 &#x…

Chrome获取RequestId

Chrome获取RequestId 参考&#xff1a;https://help.aliyun.com/zh/redis/how-do-i-obtain-the-id-of-a-request 在浏览器页面按下F12键&#xff0c;打开开发者工具页面&#xff1b; 在开发者工具页面&#xff0c;单击Network(网络)&#xff1b; 在playload(载荷)窗口中找到目…

趋动云GPU云平台部署ChatGLM-6B

目录 ChatGLM-6B是什么&#xff1f; 模型部署 Step1. 创建项目并上传代码 Step2. 环境准备 Step3. 加载模型 ChatGLM-6B是什么&#xff1f; ChatGLM-6B是一个基于GLM的生成式对话模型。由清华大学团队开发&#xff0c;旨在改进对话机器人的生成质量和逻辑。 模型部署 模…

React Native搭建Android开发环境

React Native搭建Android开发环境 搭建Android开发环境一、下载JDK二、安装Android Studio2.1 配置 ANDROID_HOME 环境变量 三、初始化项目 搭建Android开发环境 我的电脑是windows系统&#xff0c;所以只能搭建Android&#xff0c;如果电脑是mac&#xff0c;既可以搭建Androi…

Repurposing Segmentation as a Practical LVI-NULL Mitigation in SGX【USENIX`22】

目录 摘要引言贡献 背景瞬态执行攻击负载值注入LVI-NULL Intel SGX虚拟内存与分段对象重新定位 威胁模型硬件软件 摘要 负载值注入&#xff08;LVI&#xff09;在类似Spectre的混乱代理攻击中使用Meltdown类型的数据流。LVI已经在对英特尔SGX飞地的实际攻击中得到了证明&#…