组件自定义回调函数实现

想把自定义组件的点击事件抛出来执行, 但是没生效如果将函数传递到自定义组件里, 自定义组件没有action操作。

对于这种并列组件,或者是父组件需要感知子组件点击事件 使用@Watch感觉不太合适, 希望可以实现回调的方式,将事件抛出来。

HarmonyOS
2024-10-11 10:35:01
1410浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
zxjiu

尝试demo:

@Entry({ routeName: FLOW_PLAYBACK_PAGE })  
@Component  
export default struct FlowPlaybackPage {  
  
  build() {  
    Stack(){  
      Custom({  
        onClickEvent: (num:number) => {  
          this.onClickEvent2(num)  
        }  
      })  
    }  
  }  
  
  onClickEvent2 = (number:number):void =>{  
    console.log(number.toString());  
  }  
}  
  
@Component  
export struct Custom{  
  onClickEvent : (number:number) => void = ()=>{}  
  
  build() {  
    Stack()  
      .backgroundColor(Color.Black)  
      .width(200)  
      .height(200)  
      .onClick(() => {  
        this.onClickEvent(123)  
      })  
  }  
}
  • 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.
  • 31.
  • 32.
  • 33.
分享
微博
QQ
微信
回复
2024-10-11 16:36:26


相关问题
HarmonyOS 自定义interface问题
947浏览 • 1回复 待解决
@Builder自定义构建函数,如何参?
1173浏览 • 1回复 待解决
HarmonyOS CoverFlow效果自定义组件实现
1166浏览 • 1回复 待解决
HarmonyOS 自定义StepperView组件如何实现
883浏览 • 1回复 待解决
HarmonyOS 如何声明全局函数
931浏览 • 1回复 待解决
HarmonyOS 定义自定义组件
1071浏览 • 1回复 待解决
Emitter如何声明函数类型
2411浏览 • 1回复 待解决