ArkTS-自定义弹窗

在这里插入图片描述

自定义弹窗

通过CustomDialogController类显示自定义弹窗。使用弹窗组件时,可优先考虑自定义弹窗,便于自定义弹窗的样式与内容。

CustomDialogController仅在作为@CustomDialog和@Component struct的成员变量,且在@Component struct内部定义时赋值才有效,

参数名参数类型必填参数描述
builderCustomDialog自定义弹窗内容构造器。
cancel() => void点击遮障层退出时的回调。
autoCancelboolean是否允许点击遮障层退出。默认值:true
alignmentDialogAlignment弹窗在竖直方向上的对齐方式。默认值:DialogAlignment.Default
offsetOffset弹窗相对alignment所在位置的偏移量。
customStyleboolean弹窗容器样式是否自定义。默认值:false,弹窗容器的宽度根据栅格系统自适应,不跟随子节点;高度自适应子节点,最大为窗口高度的90%;圆角为24vp。
gridCount8+number弹窗宽度占栅格宽度的个数。默认为按照窗口大小自适应,异常值按默认值处理,最大栅格数为系统最大栅格数。

创建弹框组件

@CustomDialog
export struct CustomDialogExample {
  controller: CustomDialogController
  cancel: () => void
  confirm: () => void

  build() {
    Column() {
      Text('内容')
        .fontSize(20)
        .margin(20)
      Flex({
        justifyContent: FlexAlign.SpaceAround
      }) {
        Button('取消')
          .backgroundColor(0xffffff)
          .fontColor(Color.Black)
          .onClick(() => {
            this.cancel()
            this.controller.close()
          })
        Button('确认')
          .backgroundColor(0xffffff)
          .fontColor(Color.Red)
          .onClick(() => {
            this.controller.close()
            this.confirm()
          })
      }
      .margin({
        bottom:20
      })
    }
  }
}

引用弹框组件

import { CustomDialogExample } from '../views/CustomDialogExample'

@Entry
@Component
struct CustomDialogPage {
  dialogController: CustomDialogController = new CustomDialogController({
    builder: CustomDialogExample({
      cancel: this.onCancel,
      confirm: this.onAccept
    }),
    offset: { dx: 0, dy: -20 },
    alignment: DialogAlignment.Bottom, // 可设置dialog的对齐方式,设定显示在底部或中间等,默认为底部显示
  })
  @State message: string = 'Hello World'

  onCancel() {
    console.info('取消回调')
  }

  onAccept() {
    console.info('确认回调')
  }

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {
            this.dialogController.open()
          })
      }
      .width('100%')
    }
    .height('100%')
  }
}
### 创建和使用鸿蒙 ArkTS 自定义弹窗组件 #### 定义自定义弹窗组件 为了在鸿蒙 ArkTS 中创建自定义弹窗,首先需要构建一个新的组件来表示这个弹窗。这可以通过继承 `Component` 类并重写其方法来完成。 ```typescript import { Component } from '@ohos/arkui'; class CustomDialog extends Component { constructor(props) { super(props); this.state = { visible: false, }; } show() { this.setState({ visible: true }); } hide() { this.setState({ visible: false }); } render() { const style = this.state.visible ? 'visible' : 'hidden'; return ( <div class={`dialog ${style}`}> {/* Dialog content goes here */} <button onClick={() => this.hide()}>Close</button> </div> ); } } ``` 上述代码展示了如何通过设置状态变量控制弹窗显示与否[^1]。 #### 使用自定义弹窗组件 一旦完成了自定义弹窗组件的设计,在页面或其他父级组件中就可以轻松调用它了: ```typescript import React, { useState } from 'react'; // Import the custom dialog component defined above. import CustomDialog from './CustomDialog'; function App() { const [isModalVisible, setIsModalVisible] = useState(false); function showModal() { setIsModalVisible(true); } function handleOk() { console.log('Clicked ok button'); setIsModalVisible(false); } function handleCancel() { console.log('Clicked cancel button'); setIsModalVisible(false); } return ( <> <Button type="primary" onClick={showModal}> Open Modal with Custom Footer </Button> <CustomDialog title="Title Text" visible={isModalVisible} onOk={handleOk} onCancel={handleCancel} > Some contents... </CustomDialog> </> ); } ``` 这段代码片段说明了怎样引入之前创建好的 `CustomDialog` 组件,并且提供了展示与隐藏该对话框的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值