小程序如何使用防抖和节流?

news/2024/10/23 7:34:52/

防抖(Debounce)和节流(Throttle)都是用来优化函数执行频率的技术,特别在处理用户输入、滚动等频繁触发的情况下,它们可以有效减少函数的执行次数,从而提升性能和用户体验。但它们的工作方式和应用场景有所不同。

1.防抖(Debounce)

防抖的主要思想是,当持续触发事件时,在事件最后一次触发之后,只有等待一段时间没有触发新事件,才会执行函数。简言之,防抖是将多次高频触发的事件合并成一次执行。

应用场景:适用于输入框输入、搜索框自动联想等情况。例如,在用户输入过程中,只在用户停止输入后的一段时间内才触发搜索操作。

2.节流(Throttle)

节流的思想是,当持续触发事件时,保证在一定时间间隔内执行一次函数。即使在该时间间隔内触发了多次事件,也只会执行一次函数。

应用场景:适用于滚动加载、页面滚动等情况。例如,在页面滚动过程中,只在一段时间间隔内触发一次加载更多的操作。

防抖实现示例:

// pages/index/index.js
Page({debounceInput: function (e) {const value = e.detail.value;this.debouncedSearch(value);},onLoad: function () {this.debouncedSearch = this.debounce(this.search, 300);},debounce: function (func, delay) {let timer;return function (...args) {clearTimeout(timer);timer = setTimeout(() => {func.apply(this, args);}, delay);};},search: function (value) {console.log("Searching for:", value);// 实际的搜索操作},
});

在这个示例中,我们使用了防抖技术来处理用户在输入框输入时的搜索操作。在 onLoad 阶段,我们创建了一个名为 debouncedSearch 的防抖函数,将实际的搜索操作 search 作为参数传递给它。当用户输入时,会触发 debounceInput 函数,它会调用 debouncedSearch 来触发搜索操作,但只有在用户停止输入一段时间后才会真正执行搜索。

节流实现示例:

// pages/index/index.js
Page({throttleScroll: function (e) {this.throttledLoadMore();},onLoad: function () {this.throttledLoadMore = this.throttle(this.loadMore, 1000);},throttle: function (func, delay) {let lastTime = 0;return function (...args) {const now = new Date().getTime();if (now - lastTime >= delay) {func.apply(this, args);lastTime = now;}};},loadMore: function () {console.log("Loading more data...");// 实际的加载更多操作},
});

在这个示例中,我们使用了节流技术来处理页面滚动时的加载更多操作。在 onLoad 阶段,我们创建了一个名为 throttledLoadMore 的节流函数,将实际的加载更多操作 loadMore 作为参数传递给它。当页面滚动时,会触发 throttleScroll 函数,它会调用 throttledLoadMore 来触发加载更多操作,但只会在一定时间间隔内执行一次。


http://www.ppmy.cn/news/1015509.html

相关文章

【产品设计】消息通知系统设计

消息通知可以将内容实时送达用户手机页面,但是泛滥的消息通知会引起用户的反感,也违背了这个设计的初衷。 消息通知可以及时地将状态、内容的更新触达到用户,用户则可以根据收到的消息做后续判断。但是如果没有及时将重要消息触达到用户或者滥…

Unity 中检测射线穿过的所有的物体

在开发中 有个需求,射线要检测所有穿过的物体。 代码如下: using UnityEngine;public class HitCollider : MonoBehaviour {public float raycastDistance Mathf.Infinity;// Update is called once per framevoid Update(){Ray ray Camera.main.Scre…

WordPress获取文章所属分类名称或别名方法

最近在开发WordPress主题的时候&#xff0c;想要获取到文章所属分类名称或别名&#xff0c;想了半天没想到&#xff0c;于是去百度了下&#xff0c;马上就得到答案了。 非常简单&#xff0c;WordPress本身自带一个函数可以调出分类别名和链接&#xff1a; <?php the_cate…

C语言--结构体指针

结构体指针变量 引入&#xff1a; 指针就是地址&#xff0c;指针变量就是存放地址的变量 int a; int *p; p&a; 结构体也是变量 变量访问有两种方式&#xff1a;1.变量名 2.地址 struct Test t; struct Test *P; p&t; 通过结构体指针访问结构体&#xff1a;用’->来访…

2208. 将数组和减半的最少操作次数

2208. 将数组和减半的最少操作次数 给你一个正整数数组 nums 。每一次操作中&#xff0c;你可以从 nums 中选择 任意 一个数并将它减小到 恰好 一半。&#xff08;注意&#xff0c;在后续操作中你可以对减半过的数继续执行操作&#xff09; 请你返回将 nums 数组和 至少 减少一…

第五次作业 运维高级 构建 LVS-DR 集群和配置nginx负载均衡

1、基于 CentOS 7 构建 LVS-DR 群集。 LVS-DR模式工作原理 首先&#xff0c;来自客户端计算机CIP的请求被发送到Director的VIP。然后Director使用相同的VIP目的IP地址将请求发送到集群节点或真实服务器。然后&#xff0c;集群某个节点将回复该数据包&#xff0c;并将该数据包…

05 并发编程挑战,上下文切换问题,死锁问题,受限于硬件和软件的资源问题

JAVA多线程 并发编程上下文切换如何减少上下文切换减少上下文切换实战 死锁资源限制的挑战什么是资源限制资源限制引发的问题如何解决资源限制的问题在资源限制情况下进行并发编程 并发编程 有的并发程序写得不严谨&#xff0c;在并发下如果出现问题&#xff0c;定位起来会比较…

java的junit之异常测试、参数化测试、超时测试

1.对可能抛出的异常进行测试 异常本身是方法签名的一部分测试错误的输入是否导致特定的异常 summary 测试异常可以使用Test(expectedExceptio.class)对可能发生的每种类型的异常进行测试 2.参数化测试 如果待测试的输入和输出是一组数据&#xff1a; 可以把测试数据组织起…