欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react使用節(jié)流函數(shù)防止重復(fù)點擊問題

 更新時間:2023年06月07日 09:26:35   作者:cat10month  
這篇文章主要介紹了react使用節(jié)流函數(shù)防止重復(fù)點擊問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

使用節(jié)流函數(shù)防止重復(fù)點擊

react里面寫防抖和節(jié)流函數(shù)

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

節(jié)流函數(shù):

react使用節(jié)流函數(shù)

防抖函數(shù):

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

react使用防抖函數(shù)

建議直接使用lodash的throttle和debounce方法

import * as _ from 'lodash';
_.throttle(()=>{
	console.log("throttle");
}, 100);
_.debounce(()=> {
  console.log("debounce");
}, 2000

react防抖和節(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?ISR如何實現(xiàn)Demo

    詳解React?ISR如何實現(xiàn)Demo

    這篇文章主要為大家介紹了React?ISR如何實現(xiàn)Demo詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • react-beautiful-dnd 實現(xiàn)組件拖拽功能

    react-beautiful-dnd 實現(xiàn)組件拖拽功能

    這篇文章主要介紹了react-beautiful-dnd 實現(xiàn)組件拖拽功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • React使用公共文件夾public問題

    React使用公共文件夾public問題

    這篇文章主要介紹了React使用公共文件夾public問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • react中hook介紹以及使用教程

    react中hook介紹以及使用教程

    這篇文章主要給大家介紹了關(guān)于react中hook及使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 實例講解React 組件

    實例講解React 組件

    這篇文章主要介紹了React 組件的相關(guān)資料,文中示例代碼非常詳細,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • react-redux的connect與React.forwardRef結(jié)合ref失效的解決

    react-redux的connect與React.forwardRef結(jié)合ref失效的解決

    這篇文章主要介紹了react-redux的connect與React.forwardRef結(jié)合ref失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • React入門教程之Hello World以及環(huán)境搭建詳解

    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
  • 利用React實現(xiàn)虛擬列表的示例代碼

    利用React實現(xiàn)虛擬列表的示例代碼

    虛擬列表,其實就是將一個原本需要全部列表項的渲染的長列表,改為只渲染可視區(qū)域內(nèi)的列表項,但滾動效果還是要和渲染所有列表項的長列表一樣。本文就將利用React實現(xiàn)虛擬列表,需要的可以參考一下
    2022-08-08
  • React實現(xiàn)動態(tài)輪播圖的使用示例

    React實現(xiàn)動態(tài)輪播圖的使用示例

    輪播組件是常見的一種方式,用來展示圖像、信息或者是廣告,本文就來介紹一下React實現(xiàn)動態(tài)輪播圖的使用示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • JavaScript中React面向組件編程(上)

    JavaScript中React面向組件編程(上)

    本文主要介紹了React組件中默認封裝了很多屬性,有的是提供給開發(fā)者操作的,其中有三個屬性非常重要:state、props、refs。感興趣的小伙伴可以參考閱讀
    2023-03-03

最新評論