弹出框(Dialog)简易使用指南

# HarmonyOS next之弹出框(Dialog)简易使用指南

在 HarmonyOS 应用开发中,弹出框(Dialog)是一种常用的 UI 组件,用于与用户进行交互并提供重要信息或获取用户的操作确认。以下是弹出框的简易使用方法:

## 一、导入模块

在使用弹出框之前,需要导入相应的模块。通常使用以下语句导入所需的弹出框类型:

```javascript

import { TipsDialog, SelectDialog, ConfirmDialog, AlertDialog, LoadingDialog, CustomContentDialog } from '@kit.ArkUI';

```

## 二、创建弹出框控制器

每种弹出框类型都需要一个对应的控制器来管理其显示和交互。例如,创建一个`TipsDialog`的控制器:

```javascript

let dialogController = new CustomDialogController({

    builder: TipsDialog({

        // 弹出框的具体配置参数

    })

});

```

## 三、配置弹出框参数

1. 通用参数

  - `controller`:弹出框控制器,用于控制弹出框的显示、隐藏等操作。

  - `theme`(可选,从 API version 12 开始支持):主题信息,可以是自定义主题或从`onWillApplyTheme`中获取的主题实例。

  - `themeColorMode`(可选,从 API version 12 开始支持):自定义弹窗深浅色模式。

2. 特定类型弹出框参数

  - `TipsDialog`

    :

    - `imageRes`(必填,从 API version 12 + 支持`ResourceStr`或`PixelMap`):展示的图片。

    - `imageSize`(可选):自定义图片尺寸,默认值为`64*64vp`。

    - `title`(可选):提示弹出框标题。

    - `content`(可选):提示弹出框内容。

    - `checkTips`(可选):checkbox 的提示内容。

    - `isChecked`(可选,默认值为`false`):checkbox 的初始选中状态。

    - `checkAction`(可选,从 API version 12 + 推荐使用`onCheckedChange`):checkbox 选中状态改变时的回调函数。

    - `onCheckedChange`(可选,从 API version 12+):checkbox 选中状态改变事件。

    - `primaryButton`(可选):提示框左侧按钮的配置。

    - `secondaryButton`(可选):提示框右侧按钮的配置。

  - `SelectDialog`

    :

    - `title`(必填):选择弹出框标题。

    - `content`(可选):选择弹出框内容。

    - `selectedIndex`(可选,默认值为`-1`):选择弹出框的初始选中项。

    - `confirm`(可选):选择弹出框底部按钮的配置。

    - `radioContent`(必填):选择弹出框的子项内容列表,每个子项包含文本和选中回调事件。

  - `ConfirmDialog`

    :

    - `title`(必填):确认弹出框标题。

    - `content`(可选):确认弹出框内容。

    - `checkTips`(可选):checkbox 的提示内容。

    - `isChecked`(可选,默认值为`false`):checkbox 的初始选中状态。

    - `onCheckedChange`(可选,从 API version 12+):checkbox 选中状态改变事件。

    - `primaryButton`(可选):确认框左侧按钮的配置。

    - `secondaryButton`(可选):确认框右侧按钮的配置。

  - `AlertDialog`

    :

    - `primaryTitle`(可选,从 API version 12+):确认框一级标题。

    - `secondaryTitle`(可选,从 API version 12+):确认框二级标题。

    - `content`(必填):确认弹出框内容。

    - `primaryButton`(可选):确认框左侧按钮的配置。

    - `secondaryButton`(可选):确认框右侧按钮的配置。

  - `LoadingDialog`

    :

    - `content`(可选):加载弹出框内容。

  - `CustomContentDialog`(从 API version 12+)

    :

    - `contentBuilder`(必填):弹出框内容的构建函数。

    - `primaryTitle`(可选):弹出框标题。

    - `secondaryTitle`(可选):弹出框辅助文本。

    - `contentAreaPadding`(可选):弹出框内容区内边距。

    - `buttons`(可选):弹出框操作区按钮配置数组,最多支持 4 个按钮。

## 四、处理按钮点击事件

在按钮的配置中,可以设置`action`属性来定义按钮点击时的回调函数。例如:

```javascript

primaryButton: {

    value: '取消',

    action: () => {

        console.info('取消按钮被点击');

    }

}

```

## 五、显示弹出框

通过调用控制器的`open`方法来显示弹出框:

```javascript

dialogController.open();

```

通过以上步骤,就可以在 HarmonyOS 应用中使用不同类型的弹出框与用户进行交互,提供更好的用户体验。根据具体需求选择合适的弹出框类型,并根据其参数进行配置,以满足各种场景下的信息展示和操作确认需求。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容