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

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推