组件中onClick事件怎么禁止短时间内重复点击?

组件中onClick事件怎么禁止短时间内重复点击。

HarmonyOS
2024-10-11 10:59:34
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
zxjiu

可以定义一个节流函数throttle,设置间隔时间控制事件的触发。

参考代码如下:

function throttle(func: Function, interval: number) {  
  let lastTime = 0;  
  return () => {  
    const nowTime = Date.now();  
    const remainTime = interval - (nowTime - lastTime);  
    if (remainTime <= 0) {  
      lastTime = nowTime;  
      func();  
    }  
  };  
}  
  
@Entry  
@Component  
struct Index {  
  @State num: number = 0  
  
  build() {  
    Row() {  
      Column() {  
        Text(this.num.toString())  
        Button("click").onClick(throttle(() => {  
          this.num++  
        }, 5000))  
      }  
      .width('100%')  
    }  
    .height('100%')  
  }  
}
分享
微博
QQ
微信
回复
2024-10-11 16:23:29
相关问题
怎么透传onClick事件
317浏览 • 1回复 待解决
如何禁止Button的点击事件
617浏览 • 1回复 待解决
HarmonyOS 按钮怎么防止重复点击
27浏览 • 1回复 待解决
组件如何处理子组件点击事件
2772浏览 • 1回复 待解决
HarmonyOS 防重复点击问题
28浏览 • 1回复 待解决
长按事件如何重复触发
2113浏览 • 1回复 待解决