如何实现事件透传,你会吗?

​例如在一个Stack中,有两个兄弟组件,组件A被组件B盖住,用户点击组件B时能否将点击事件透传至组件A,触发组件A的onClick回调而不触发组件B的onClick回调。

HarmonyOS
2024-01-21 12:56:02
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
荣光因缘来

组件B设置hitTestBehavior属性为HitTestMode.None即可。

代码示例

@Entry 
@Component 
struct StackExample { 
  build() { 
    Stack({ alignContent: Alignment.Bottom }) { 
      Text('A') 
        .width('90%') 
        .height('100%') 
        .backgroundColor(0xd2cab3) 
        .align(Alignment.Top) 
        .onClick(() => { 
          console.log('11111') 
        }) 
      Text('B') 
        .width('70%') 
        .height('60%') 
        .backgroundColor(0xc1cbac) 
        .align(Alignment.Top) 
        .hitTestBehavior(HitTestMode.None) 
        .onClick(() => { 
          console.log('1111122222') 
        }) 
    }.width('100%').height(150).margin({ top: 5 }) 
  } 
}

参考链接

触摸测试控制

分享
微博
QQ
微信
回复
2024-01-22 15:20:48
相关问题
怎么onClick事件
308浏览 • 1回复 待解决
两个重叠的组件如何实现事件
637浏览 • 1回复 待解决
customDialog焦点
859浏览 • 1回复 待解决
HarmonyOS 弹层的点击事件处理
67浏览 • 1回复 待解决
如何获取设备信息,
2313浏览 • 1回复 待解决
如何设置沉浸式窗口,
1940浏览 • 1回复 待解决
如何使应用一键变灰,
2558浏览 • 1回复 待解决
如何实现多行输入,知道
1909浏览 • 1回复 待解决
如何退出应用,了解
2470浏览 • 1回复 待解决
如何创建Toast窗口,知道
1787浏览 • 1回复 待解决
如何将点击事件传到下一层
1917浏览 • 1回复 待解决
如何获取屏幕宽高,知道
2466浏览 • 1回复 待解决
如何保持屏幕常亮,知道
2333浏览 • 1回复 待解决
如何后台播放音乐,知道
2382浏览 • 1回复 待解决
如何获取系统时间戳,知道
2891浏览 • 1回复 待解决
如何获取图片的宽高,知道
2453浏览 • 1回复 待解决
如何主动拉起软键盘,知道
2428浏览 • 1回复 待解决
愿意尝试华为「鸿蒙」系统?
10493浏览 • 6回复 待解决