# 自定义弹窗
>![](../../public_sys-resources/icon-note.gif) **说明:**
>从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
通过CustomDialogController类显示自定义弹窗。
## 接口
CustomDialogController\(value:\{builder: CustomDialog, cancel?: \(\) =\> void, autoCancel?: boolean\}\)
- 参数
参数名
|
参数类型
|
必填
|
默认值
|
参数描述
|
builder
|
CustomDialog
|
是
|
-
|
自定义弹窗内容构造器。
|
cancel
|
() => void
|
否
|
-
|
点击遮障层退出时的回调。
|
autoCancel
|
boolean
|
否
|
true
|
是否允许点击遮障层退出。
|
alignment
|
DialogAlignment
|
否
|
DialogAlignment.Default
|
弹窗在竖直方向上的对齐方式。
|
offset
|
{
dx: Length | Resource,
dy: Length | Resource
}
|
否
|
-
|
弹窗相对alignment所在位置的偏移量。
|
customStyle
|
boolean
|
否
|
false
|
弹窗容器样式是否自定义。
|
- DialogAlignment枚举说明
名称
|
描述
|
Top
|
垂直顶部对齐。
|
Center
|
垂直居中对齐。
|
Bottom
|
垂直底部对齐。
|
Default
|
默认对齐。
|
### CustomDialogController
创建对象
```
dialogController : CustomDialogController = new CustomDialogController(value:{builder: CustomDialog, cancel?: () => void, autoCancel?: boolean})
```
open\(\)
显示自定义弹窗内容,若已显示,则不生效。
close\(\)
关闭显示的自定义弹窗,若已关闭,则不生效。
## 示例
```
@CustomDialog
struct CustomDialogExample {
controller: CustomDialogController
cancel: () => void
confirm: () => void
build() {
Column() {
Text('Software uninstall').width('70%').fontSize(20).margin({ top: 10, bottom: 10 })
Image($r('app.media.icon')).width(80).height(80)
Text('Whether to uninstall a software?').fontSize(16).margin({ bottom: 10 })
Flex({ justifyContent: FlexAlign.SpaceAround }) {
Button('cancel')
.onClick(() => {
this.controller.close()
this.cancel()
}).backgroundColor(0xffffff).fontColor(Color.Black)
Button('confirm')
.onClick(() => {
this.controller.close()
this.confirm()
}).backgroundColor(0xffffff).fontColor(Color.Red)
}.margin({ bottom: 10 })
}
}
}
@Entry
@Component
struct CustomDialogUser {
dialogController: CustomDialogController = new CustomDialogController({
builder: CustomDialogExample({ cancel: this.onCancel, confirm: this.onAccept }),
cancel: this.existApp,
autoCancel: true
})
onCancel() {
console.info('Callback when the first button is clicked')
}
onAccept() {
console.info('Callback when the second button is clicked')
}
existApp() {
console.info('Click the callback in the blank area')
}
build() {
Column() {
Button('click me')
.onClick(() => {
this.dialogController.open()
}).backgroundColor(0x317aff)
}.width('100%').margin({ top: 5 })
}
}
```
![](figures/customdialog.gif)