组件中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%')  
  }  
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
分享
微博
QQ
微信
回复
2024-10-11 16:23:29


相关问题
如何禁止Button的点击事件
1320浏览 • 1回复 待解决
怎么透传onClick事件
890浏览 • 1回复 待解决
HarmonyOS 按钮怎么防止重复点击
969浏览 • 1回复 待解决
HarmonyOS 防重复点击
491浏览 • 1回复 待解决
组件如何处理子组件点击事件
3657浏览 • 1回复 待解决
HarmonyOS 防重复点击问题
644浏览 • 1回复 待解决
HarmonyOS onClick事件如何阻止事件冒泡
921浏览 • 1回复 待解决
长按事件如何重复触发
2793浏览 • 1回复 待解决
HarmonyOS ListItem的onClick事件触发问题
1171浏览 • 1回复 待解决