react 点击两次_React Native 防止重复点击,触发多次事件

在React Native中,未处理的点击事件可能导致触发多次。为解决此问题,可以创建一个名为HandlerOnceTap.js的自定义JS文件,通过设置定时器确保事件只执行一次。在需要使用的地方导入这个文件,将原来的onPress事件替换为HandlerOnceTap包裹的函数,从而避免因快速点击导致的多次执行问题。

RN的好处在这里就不多做介绍,下面直接看一个bug

一般情况,RN的点击事件如果不做特殊处理话,点击快一点都会出现触发两次或者多次的情况,下面提供一种解决方案,

1、自定义一个js文件 HandlerOnceTap.js

let isCalled = false, timer;

/**

* @param functionTobeCalled method 对调函数体

* @param interval 定时器

*/

export default HandlerOnceTap = (functionTobeCalled, interval = 600) => {

if (!isCalled) {

isCalled = true;

clearTimeout(timer);

timer = setTimeout(() => {

isCalled = false;

}, interval);

return functionTobeCalled();

}

};

2、 在需要使用的地方import 自定义的js文件

import HandlerOnceTap from '../HandlerOnceTap';

// 一定要保证路径的准确性

没有使用之前的代码如下

onPress={() => {

Alert.alert(

I18N.t('alert'),

I18N.t('continue'),

[

{ text: I18N.t('no'), onPress: () => console.log('Cancel Pressed') },

{ text: I18N.t('yes'), onPress: () => this.selectSession(item.item) },

],

{ cancelable: false },

);

}}

这种情况下,快速点击按钮会触发两次,导致alert两次,其他场景,比如在push下一个页面的时候也会出现这样的情况,那么我们就可以用下面的方法代替

使用定时器后的方法如下

onPress={() => HandlerOnceTap(() => {

Alert.alert(

I18N.t('alert'),

I18N.t('continue'),

[

{ text: I18N.t('no'), onPress: () => console.log('Cancel Pressed') },

{ text: I18N.t('yes'), onPress: () => this.selectSession(item.item) },

],

{ cancelable: false },

);

})}

这样快速点击的时候,就不会出现触发两次的情况了

当然也可以定义一个全局的变量,也能解决push页面的问题,这里不做细致介绍

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值