4.手写JavaScript防抖、节流和函数柯里化

2024-04-07 04:52

本文主要是介绍4.手写JavaScript防抖、节流和函数柯里化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、核心思想:

1.防抖

事件触发后开启一个定时器,如果事件在这个定时器限定的时间内再次触发,则清除定时器,在写一个定时器,定时时间到则触发。简单理解防抖是让函数在延迟时间到达后触发,如果期间再次点击则延迟重新计算,直到延迟时间为0后函数触发。

2.节流

设计一种类似控制阀门一样定期开放的函数,事件触发时让函数执行一次,然后关闭这个阀门,过了一段时间后再将这个阀门打开,再次触发事件。简单理解节流就是延迟时间内只触发一次。

3.函数柯里化

函数柯里化 其实就是函数颗粒化 将一个函数变成一个个颗粒可以组装,就是这个里面的多个参数 将他变成一个个的函数来传递这个参数。

ps:

三者原理都基于闭包,下面简单写下闭包的相关知识

1.概念:

闭包是函数嵌套函数,内部函数可以引用外部函数的参数和变量。参数和变量不会被垃圾回收机制收回。

2.从全局变量和局部变量出发:

(1)闭包拥有全局变量的不被释放的特点。(2)闭包拥有局部变量的无法被外部访问的特点

3.闭包的好处:

(1)可以让一个变量长期在内存中不被释放

(2)避免全局变量的污染,和全局变量不同,闭包中的变量无法被外部使用

(3)私有成员的存在,无法被外部调用,只能直接内部调用

二、代码实现:

1.防抖

<body>手写防抖<input type="text" id="input1">
</body>
let input1 = document.getElementById("input1");
/*** 手写防抖函数* @param {Function} 传入方法* @param {number} 延迟时间* @return {Function} 返回方法*/
function debounce(fn, delay) {let time = null;return function () {if (time) {clearTimeout(time);time = null;}time = setTimeout(() => {fn.apply(this, arguments);}, delay);};
}
input1.addEventListener("input",debounce(function () {console.log(this.value);}, 1000)
);
//特别注意addEventListener方法第二个参数事件触发后调用的函数,第三个参数是个布尔值用于描述事件是冒泡还是捕获。该参数是可选的。默认false即冒泡,由内向外。面试可能会问

2.节流

<body>手写节流<input type="button" id="input2" value="手写节流">
</body>
/*** 手写节流函数* @param {Function} 传入方法* @param {number} 延迟时间* @return {Function} 返回方法*/
function throttle(fn, delay) {let time = null;return function () {if (!time) {fn.call(this, arguments);time = setTimeout(() => {clearTimeout(time);time = null;}, delay);}};
}
input2.addEventListener("click",throttle(function () {console.log(123);}, 2000)
);

3.简单的函数柯里化

/*** 手写Curry函数* @param {Function} 传入方法* @return {Number} 返回求和结果*/
function curry(fn) {return function (a) {return function (b) {return function (c) {return fn(a, b, c);};};};
}
function sumFn(a, b, c) {return a + b + c;
}
console.log(curry(sumFn)(1)(2)(3));
//6

这篇关于4.手写JavaScript防抖、节流和函数柯里化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/881681

相关文章

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Springboot的自动配置是什么及注意事项

《Springboot的自动配置是什么及注意事项》SpringBoot的自动配置(Auto-configuration)是指框架根据项目的依赖和应用程序的环境自动配置Spring应用上下文中的Bean... 目录核心概念:自动配置的关键特点:自动配置工作原理:示例:需要注意的点1.默认配置可能不适合所有场景

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行