這篇文章主要介紹了react避免重復(fù)點(diǎn)擊的方法,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)憑借專業(yè)的設(shè)計(jì)團(tuán)隊(duì)扎實(shí)的技術(shù)支持、優(yōu)質(zhì)高效的服務(wù)意識(shí)和豐厚的資源優(yōu)勢,提供專業(yè)的網(wǎng)站策劃、成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、網(wǎng)站優(yōu)化、軟件開發(fā)、網(wǎng)站改版等服務(wù),在成都十多年的網(wǎng)站建設(shè)設(shè)計(jì)經(jīng)驗(yàn),為成都上千多家中小型企業(yè)策劃設(shè)計(jì)了網(wǎng)站。
防止重復(fù)點(diǎn)擊的思路:
在請求數(shù)據(jù)一旦開始,直到本次請求結(jié)束之前,不能進(jìn)行下一次點(diǎn)擊,否則給與相應(yīng)的提示。
具體方法:
state中的初始設(shè)置:
state={ bool:true, }
點(diǎn)擊事件設(shè)置:
btn_click = async () => { this.setState({ bool: false, }) . . . if(this.state.bool){ const value = await fetch.bbb({}) if (value.code == 1) { } else { } this.setState({ bool: true, }) } }
解析:
滿足bool為true的情況,我們執(zhí)行請求,如果發(fā)生多次點(diǎn)擊的情況,方法開頭設(shè)置的bool:false就會(huì)生效,防止在請求還沒有完成的情況下進(jìn)行下一次請求;
然后在請求完成之后,我們把Bool的狀態(tài)變更多來,以便此次請求完成還可以進(jìn)行下一次請求。
至于方法開頭設(shè)置為false,請求還執(zhí)行,是源于一個(gè)異步機(jī)制,在同一個(gè)方法中設(shè)置state又重新調(diào)用,state是來不及更新的,但是會(huì)在下一次調(diào)用該方法的時(shí)候執(zhí)行。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“react避免重復(fù)點(diǎn)擊的方法”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!