React Native防止重復點擊

眾所周知秀鞭,目前RN的反應速度距離原生還是差一點點痴脾,再加上本人單身25年的手速那更是比平常人快了不是一點半點,所以經常導致點擊多下沒反應(暫時沒反應)掸犬,之后打開n多相同的界面(具體多少那就要看你手速了)珊楼。本篇就是為了解決這一問題而存在的通殃,閑話少說,見正文:

情景一:

直接點擊跳轉到下一個頁面:
在constructor中初始化state厕宗,設置isDisable初始值為false画舌。

    constructor(props) {
        super(props);
        this.state = {
            isDisable: false,
        };
    }

在需要防止點擊的地方加入,有的控件可能沒有點擊事件已慢,在這里需要用下面這三個簡單封裝一下曲聂。因為TouchableHighlightTouchableNativeFeedback佑惠,TouchableOpacity這三個都繼承TouchableWithoutFeedback所有的屬性朋腋,所以在這里用disabled這個屬性來控制是否可點擊齐疙。

Paste_Image.png
<TouchableHighlight
    disabled={this.state.isDisable}
    onPress={() => {
                        this.setState({isDisable: true});
                    }}
 </TouchableHighlight>

情景二:

跳轉到下一個頁面,還會返回的:
直接在上述onPress方法中旭咽,添加一個定時器

   this.timer = setTimeout(
                            () => {
                                this.setState({isDisable: false});
                            },
                            1000
                        );

為了防止發(fā)生致命錯誤(閃退)是與計時器有關剂碴,具體來說,是在某個組件被卸載(unmount)之后轻专,計時器卻仍然在運行。需要在unmount組件時清除(clearTimeout/clearInterval)所有用到的定時器察蹲,代碼如下:

 componentWillUnmount() {
        // 請注意Un"m"ount的m是小寫

        // 如果存在this.timer请垛,則使用clearTimeout清空。
        // 如果你使用多個timer洽议,那么用多個變量宗收,或者用個數組來保存引用,然后逐個clear
        this.timer && clearTimeout(this.timer);
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末亚兄,一起剝皮案震驚了整個濱河市混稽,隨后出現的幾起案子,更是在濱河造成了極大的恐慌审胚,老刑警劉巖匈勋,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異膳叨,居然都是意外死亡洽洁,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門菲嘴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來饿自,“玉大人,你說我怎么就攤上這事龄坪≌汛疲” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵健田,是天一觀的道長烛卧。 經常有香客問我,道長妓局,這世上最難降的妖魔是什么唱星? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮跟磨,結果婚禮上间聊,老公的妹妹穿的比我還像新娘。我一直安慰自己抵拘,他們只是感情好哎榴,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般尚蝌。 火紅的嫁衣襯著肌膚如雪迎变。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天飘言,我揣著相機與錄音衣形,去河邊找鬼。 笑死姿鸿,一個胖子當著我的面吹牛谆吴,可吹牛的內容都是我干的。 我是一名探鬼主播苛预,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼句狼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了热某?” 一聲冷哼從身側響起腻菇,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎昔馋,沒想到半個月后筹吐,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡秘遏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年骏令,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垄提。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡榔袋,死狀恐怖,靈堂內的尸體忽然破棺而出铡俐,到底是詐尸還是另有隱情凰兑,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布审丘,位于F島的核電站吏够,受9級特大地震影響,放射性物質發(fā)生泄漏滩报。R本人自食惡果不足惜锅知,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望脓钾。 院中可真熱鬧售睹,春花似錦、人聲如沸可训。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至飞崖,卻和暖如春烂叔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背固歪。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工蒜鸡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人牢裳。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓逢防,卻偏偏與公主長得像,于是被迫代替她去往敵國和親贰健。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容