react使用節(jié)流函數(shù)防止重復(fù)點擊問題
使用節(jié)流函數(shù)防止重復(fù)點擊
react里面寫防抖和節(jié)流函數(shù)
節(jié)流函數(shù)利用閉包來設(shè)置定時器,節(jié)流函數(shù)3s內(nèi)只能點擊一次,點擊后立即觸發(fā),重復(fù)點擊無效,必須等3s之后才能點擊第二次
節(jié)流函數(shù):

防抖函數(shù):
防抖函數(shù)3s之后出結(jié)果,重復(fù)點擊無效,如果重復(fù)點擊了,重新計算3s時間,從點擊的時刻算起,必須等待3s時間觸發(fā)事件

建議直接使用lodash的throttle和debounce方法
import * as _ from 'lodash';
_.throttle(()=>{
console.log("throttle");
}, 100);
_.debounce(()=> {
console.log("debounce");
}, 2000react防抖和節(jié)流
定義
- 節(jié)流: 一段時間內(nèi)只運行一次,若在這段時間內(nèi)重復(fù)觸發(fā),只有第一次生效
- 防抖: 一段時間后在執(zhí)行該事件,若在這段時間內(nèi)被重復(fù)觸發(fā),則重新計時
節(jié)流一般用在按鈕上,防抖一般用在搜索上
節(jié)流
// 這個是點第一次的時候立即生效,接下來在一定時間內(nèi)再點就不生效了,直到這段時間過去
function throttle (fn, delay) {
? ? let flag = true;
? ? return function () {
? ? ? ? if(flag){
? ? ? ? ? ? flag = false;
? ? ? ? ? ? fn();
? ? ? ? ? ? setTimeout(() => {
? ? ? ? ? ? ? ? flag = true;
? ? ? ? ? ? }, delay); ??
? ? ? ? } ? ?
? ? }
}
// 這個是點第一次的時候不生效,直到這段時間過去無論點了多少次只有一次生效
function throttle (fn, delay) {
? ? let flag = true;
? ? return function () {
? ? ? ? if(flag){
? ? ? ? ? ? flag = false; // 這個放在上面還是下面應(yīng)該都可以
? ? ? ? ? ? setTimeout(() => {
? ? ? ? ? ? ? ? fn();
? ? ? ? ? ? ? ? flag = true;
? ? ? ? ? ? }, delay); ??
? ? ? ? } ? ?
? ? }
}防抖
// 一段時間后執(zhí)行某段代碼,如果在這段時間之內(nèi)再次點擊了,會清除當(dāng)前的定時器,重新開一個定時器
// 直到時間結(jié)束這段代碼被執(zhí)行,不然會一直重復(fù)這個過程,這段代碼一直不會被執(zhí)行
function debounce(fn, delay){
? ? let timer = null;
? ? return function(){
? ? ? ? clearTimeout(timer);
? ? ? ? timer = setTimeout(()=> {
? ? ? ? ? ? fn();
? ? ? ? }, delay)
? ? }
}react封裝好的防抖和節(jié)流
第三方函數(shù)工具庫:lodash
安裝:npm i lodash
引入:import _ from 'lodash'
// 防抖 ?反復(fù)觸發(fā)執(zhí)行最后一次 //使用useCallback防止debounce失效
? const debounce = _.debounce;
? const getSuggestion = useCallback(
? ? debounce((val: string, type: boolean) => {
? ? ? type ? message.success(val) : message.warning(val);
? ? }, 300),
? ? [],
);
// 節(jié)流
const throttle = _.throttle;
const getSuggestion =?
throttle((val: string, type: boolean) => {
? ? type ? message.success(val) : message.warning(val);
}, 300);總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
react-beautiful-dnd 實現(xiàn)組件拖拽功能
這篇文章主要介紹了react-beautiful-dnd 實現(xiàn)組件拖拽功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08
react-redux的connect與React.forwardRef結(jié)合ref失效的解決
這篇文章主要介紹了react-redux的connect與React.forwardRef結(jié)合ref失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
React入門教程之Hello World以及環(huán)境搭建詳解
Facebook 為了開發(fā)一套更好更適合自己的JavaScript MVC 框架,所以產(chǎn)生了react。后來反響很好,所以于2013年5月開源。下面這篇文章主要給大家介紹了關(guān)于React入門教程之Hello World以及環(huán)境搭建的相關(guān)資料,需要的朋友可以參考借鑒。2017-07-07

