react避免重復(fù)點(diǎn)擊的方法

這篇文章主要介紹了react避免重復(fù)點(diǎn)擊的方法,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)憑借專(zhuān)業(yè)的設(shè)計(jì)團(tuán)隊(duì)扎實(shí)的技術(shù)支持、優(yōu)質(zhì)高效的服務(wù)意識(shí)和豐厚的資源優(yōu)勢(shì),提供專(zhuān)業(yè)的網(wǎng)站策劃、成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、網(wǎng)站優(yōu)化、軟件開(kāi)發(fā)、網(wǎng)站改版等服務(wù),在成都十多年的網(wǎng)站建設(shè)設(shè)計(jì)經(jīng)驗(yàn),為成都上千多家中小型企業(yè)策劃設(shè)計(jì)了網(wǎng)站。

防止重復(fù)點(diǎn)擊的思路:

在請(qǐng)求數(shù)據(jù)一旦開(kāi)始,直到本次請(qǐng)求結(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,
		})
	}
}

解析:

滿(mǎn)足bool為true的情況,我們執(zhí)行請(qǐng)求,如果發(fā)生多次點(diǎn)擊的情況,方法開(kāi)頭設(shè)置的bool:false就會(huì)生效,防止在請(qǐng)求還沒(méi)有完成的情況下進(jìn)行下一次請(qǐng)求;

然后在請(qǐng)求完成之后,我們把Bool的狀態(tài)變更多來(lái),以便此次請(qǐng)求完成還可以進(jìn)行下一次請(qǐng)求。

至于方法開(kāi)頭設(shè)置為false,請(qǐng)求還執(zhí)行,是源于一個(gè)異步機(jī)制,在同一個(gè)方法中設(shè)置state又重新調(diào)用,state是來(lái)不及更新的,但是會(huì)在下一次調(diào)用該方法的時(shí)候執(zhí)行。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“react避免重復(fù)點(diǎn)擊的方法”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

網(wǎng)站名稱(chēng):react避免重復(fù)點(diǎn)擊的方法
URL鏈接:http://bm7419.com/article48/geejhp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、云服務(wù)器App開(kāi)發(fā)、網(wǎng)站制作、App設(shè)計(jì)面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司