class="hide-preCode-box">
  • 页面内需要在构造器内进行接收,同时创建相应的函数操作。

    @Entry
    @Component
    struct CustomDialogUser {
      dialogController: CustomDialogController = new CustomDialogController({
        builder: CustomDialogExample({
          cancel: ()=> { this.onCancel() },
          confirm: ()=> { this.onAccept() },
        }),
      })
    
      onCancel() {
        console.info('Callback when the first button is clicked')
      }
    
      onAccept() {
        console.info('Callback when the second button is clicked')
      }
    
      build() {
        Column() {
          Button('click me')
            .onClick(() => {
              this.dialogController.open()
            })
        }.width('100%').margin({ top: 5 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

    3.可通过弹出框中的按钮实现路由跳转,同时获取跳转页面向当前页传入的参数。

    // Index.ets
    @CustomDialog
    struct CustomDialogExample {
      @Link textValue: string
      controller?: CustomDialogController
      cancel: () => void = () => {
      }
      confirm: () => void = () => {
      }
    
      build() {
        Column({ space: 20 }) {
          if (this.textValue != '') {
            Text(`第二个页面的内容为:${this.textValue}`)
              .fontSize(20)
          } else {
            Text('是否获取第二个页面的内容')
              .fontSize(20)
          }
          Flex({ justifyContent: FlexAlign.SpaceAround }) {
            Button('cancel')
              .onClick(() => {
                if (this.controller != undefined) {
                  this.controller.close()
                  this.cancel()
                }
              }).backgroundColor(0xffffff).fontColor(Color.Black)
            Button('confirm')
              .onClick(() => {
                if (this.controller != undefined && this.textValue != '') {
                  this.controller.close()
                } else if (this.controller != undefined) {
                  this.getUIContext().getRouter().pushUrl({
                    url: 'pages/Index2'
                  })
                  this.controller.close()
                }
              }).backgroundColor(0xffffff).fontColor(Color.Red)
          }.margin({ bottom: 10 })
        }.borderRadius(10).padding({ top: 20 })
      }
    }
    
    @Entry
    @Component
    struct CustomDialogUser {
      @State textValue: string = ''
      dialogController: CustomDialogController | null = new CustomDialogController({
        builder: CustomDialogExample({
          cancel: () => {
            this.onCancel()
          },
          confirm: () => {
            this.onAccept()
          },
          textValue: $textValue
        })
      })
    
      // 在自定义组件即将析构销毁时将dialogController置空
      aboutToDisappear() {
        this.dialogController = null // 将dialogController置空
      }
    
      onPageShow() {
        const params = this.getUIContext().getRouter().getParams() as Record; // 获取传递过来的参数对象
        if (params) {
          this.dialogController?.open()
          this.textValue = params.info as string; // 获取info属性的值
        }
      }
    
      onCancel() {
        console.info('Callback when the first button is clicked')
      }
    
      onAccept() {
        console.info('Callback when the second button is clicked')
      }
    
      exitApp() {
        console.info('Click the callback in the blank area')
      }
    
      build() {
        Column() {
          Button('click me')
            .onClick(() => {
              if (this.dialogController != null) {
                this.dialogController.open()
              }
            }).backgroundColor(0x317aff)
        }.width('100%').margin({ top: 5 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">
    // Index2.ets
    @Entry
    @Component
    struct Index2 {
      @State message: string = '点击返回';
      build() {
        Column() {
          Button(this.message)
            .fontSize(50)
            .fontWeight(FontWeight.Bold).onClick(() => {
            this.getUIContext().getRouter().back({
              url: 'pages/Index',
              params: {
                info: 'Hello World'
              }
            });
          })
        }.width('100%').height('100%').margin({ top: 20 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 弹出框的动画

    弹出框通过定义openAnimation控制弹出框出现动画的持续时间,速度等参数。

    @CustomDialog
    struct CustomDialogExample {
      controller?: CustomDialogController
    
      build() {
        Column() {
          Text('Whether to change a text?').fontSize(16).margin({ bottom: 10 })
        }
      }
    }
    
    @Entry
    @Component
    struct CustomDialogUser {
      @State textValue: string = ''
      @State inputValue: string = 'click me'
      dialogController: CustomDialogController | null = new CustomDialogController({
        builder: CustomDialogExample(),
        openAnimation: {
          duration: 1200,
          curve: Curve.Friction,
          delay: 500,
          playMode: PlayMode.Alternate,
          onFinish: () => {
            console.info('play end')
          }
        },
        autoCancel: true,
        alignment: DialogAlignment.Bottom,
        offset: { dx: 0, dy: -20 },
        gridCount: 4,
        customStyle: false,
        backgroundColor: 0xd9ffffff,
        cornerRadius: 10,
      })
    
      // 在自定义组件即将析构销毁时将dialogController置空
      aboutToDisappear() {
        this.dialogController = null // 将dialogController置空
      }
    
      build() {
        Column() {
          Button(this.inputValue)
            .onClick(() => {
              if (this.dialogController != null) {
                this.dialogController.open()
              }
            }).backgroundColor(0x317aff)
        }.width('100%').margin({ top: 5 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

    弹出框的样式

    弹出框通过定义宽度、高度、背景色、阴影等参数来控制样式。

    @CustomDialog
    struct CustomDialogExample {
      controller?: CustomDialogController
    
      build() {
        Column() {
          Text('我是内容').fontSize(16).margin({ bottom: 10 })
        }
      }
    }
    
    @Entry
    @Component
    struct CustomDialogUser {
      @State textValue: string = ''
      @State inputValue: string = 'click me'
      dialogController: CustomDialogController | null = new CustomDialogController({
        builder: CustomDialogExample(),
        autoCancel: true,
        alignment: DialogAlignment.Center,
        offset: { dx: 0, dy: -20 },
        gridCount: 4,
        customStyle: false,
        backgroundColor: 0xd9ffffff,
        cornerRadius: 20,
        width: '80%',
        height: '100px',
        borderWidth: 1,
        borderStyle: BorderStyle.Dashed,//使用borderStyle属性,需要和borderWidth属性一起使用
        borderColor: Color.Blue,//使用borderColor属性,需要和borderWidth属性一起使用
        shadow: ({ radius: 20, color: Color.Grey, offsetX: 50, offsetY: 0}),
      })
    
      // 在自定义组件即将析构销毁时将dialogController置空
      aboutToDisappear() {
        this.dialogController = null // 将dialogController置空
      }
    
      build() {
        Column() {
          Button(this.inputValue)
            .onClick(() => {
              if (this.dialogController != null) {
                this.dialogController.open()
              }
            }).backgroundColor(0x317aff)
        }.width('100%').margin({ top: 5 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

    嵌套自定义弹出框

    通过第一个弹出框打开第二个弹出框时,最好将第二个弹出框定义在第一个弹出框的父组件处,通过父组件传给第一个弹出框的回调来打开第二个弹出框。

    @CustomDialog
    struct CustomDialogExampleTwo {
      controllerTwo?: CustomDialogController
      @State message: string = "I'm the second dialog box."
      @State showIf: boolean = false;
      build() {
        Column() {
          if (this.showIf) {
            Text("Text")
              .fontSize(30)
              .height(100)
          }
          Text(this.message)
            .fontSize(30)
            .height(100)
          Button("Create Text")
            .onClick(()=>{
              this.showIf = true;
            })
          Button ('Close Second Dialog Box')
            .onClick(() => {
              if (this.controllerTwo != undefined) {
                this.controllerTwo.close()
              }
            })
            .margin(20)
        }
      }
    }
    @CustomDialog
    struct CustomDialogExample {
      openSecondBox?: ()=>void
      controller?: CustomDialogController
    
      build() {
        Column() {
          Button ('Open Second Dialog Box and close this box')
            .onClick(() => {
              this.controller!.close();
              this.openSecondBox!();
            })
            .margin(20)
        }.borderRadius(10)
      }
    }
    @Entry
    @Component
    struct CustomDialogUser {
      @State inputValue: string = 'Click Me'
      dialogController: CustomDialogController | null = new CustomDialogController({
        builder: CustomDialogExample({
          openSecondBox: ()=>{
            if (this.dialogControllerTwo != null) {
              this.dialogControllerTwo.open()
            }
          }
        }),
        cancel: this.exitApp,
        autoCancel: true,
        alignment: DialogAlignment.Bottom,
        offset: { dx: 0, dy: -20 },
        gridCount: 4,
        customStyle: false
      })
      dialogControllerTwo: CustomDialogController | null = new CustomDialogController({
        builder: CustomDialogExampleTwo(),
        alignment: DialogAlignment.Bottom,
        offset: { dx: 0, dy: -25 } })
    
      aboutToDisappear() {
        this.dialogController = null
        this.dialogControllerTwo = null
      }
    
      onCancel() {
        console.info('Callback when the first button is clicked')
      }
    
      onAccept() {
        console.info('Callback when the second button is clicked')
      }
    
      exitApp() {
        console.info('Click the callback in the blank area')
      }
      build() {
        Column() {
          Button(this.inputValue)
            .onClick(() => {
              if (this.dialogController != null) {
                this.dialogController.open()
              }
            }).backgroundColor(0x317aff)
        }.width('100%').margin({ top: 5 })
      }
    }
    ts
     class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"> class="hide-preCode-box">

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

    由于自定义弹出框在状态管理侧有父子关系,如果将第二个弹出框定义在第一个弹出框内,那么当父组件(第一个弹出框)被销毁(关闭)时,子组件(第二个弹出框)内无法再继续创建新的组件。

    data-report-view="{"mod":"1585297308_001","spm":"1001.2101.3001.6548","dest":"https://blog.csdn.net/adsjgfjha123123/article/details/144544246","extend1":"pc","ab":"new"}">>
    注:本文转载自blog.csdn.net的郁闷的黄米鸡的文章"https://blog.csdn.net/adsjgfjha123123/article/details/144544246"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
    复制链接

    评论记录:

    未查询到任何数据!