鸿蒙弹窗实现乱象?带你玩转正确的实现姿势

news2024/11/21 11:34:07

最近看到很多童鞋吐槽鸿蒙自定义弹窗的实现,也有不少童鞋提供了各式各样的低耦,轻巧方向的优化方案,但多数参差不齐,甚至有基于老API(白玩,以后还得废弃掉…)给的方案,为避免如此“乱象”遂提出正确的实现姿势。

姿势一

如果您没有特别的要求,系统AlertDialog(API 6+)完全够用

代码示例:

AlertDialog.show({
      title: '温馨提示',
      message: '您确认要退出登录吗?',
      autoCancel: true, //点击窗口外边是否自动关闭
      alignment: DialogAlignment.Center, //弹窗位置
      cornerRadius: 8,
      primaryButton: {
        value: '确认',
        action: () => {
          toast.show('点击了确认按钮')
        }
      },
      secondaryButton: {
        value: '取消',
        action: () => {
          toast.show('点击了取消按钮')
        }
      },
      cancel: () => {
          toast.show('点击弹窗外导致的取消回调')
      }
    })

效果是酱紫的:

demo0

系统AlertDialog还可以定制一些特别的样式:

demo1

具体就不代码举例了,感兴趣的童鞋可以参考官网demo哈

姿势二

很多时候,系统AlertDialog并不能满足精致化的业务需求,那么API 7给您带来了饱受诟病和吐槽的CustomDialog(API 6+)来方便开发者自定义弹窗

代码示例:

@CustomDialog
@Preview
export struct CommonDialog {
  title: string | Resource = "温馨提示"
  msg: string | Resource = ""
  confirm: string | Resource = "确认"
  cancel: string | Resource = "取消"
  controller?: CustomDialogController
  onCancel: () => void = () => {
  }
  onConfirm: () => void = () => {
  }

  build() {
    Column({ space: 30 }) {
      Text(this.title)
        ......

      Text(this.msg)
        ......
        
      Flex({ justifyContent: FlexAlign.SpaceAround }) {
        Button(this.cancel)
          .onClick(() => {
            if (this.controller) {
              this.controller.close()
              this.onCancel()
            }
          })
          ......

        Button(this.confirm)
          .onClick(() => {
            if (this.controller) {
              this.controller.close()
              this.onConfirm()
            }
          })
          ......
      }
    }
  }
}

然后在组件中配置和唤起:

@Entry
@Component
struct ToolTestPage {
  private dialogController: CustomDialogController = new CustomDialogController({
    builder: CommonDialog({
      onCancel: () => {
        toast.show("你点了取消")
      },
      onConfirm: () => {
        toast.showLong("你点了确认")
      },
      title: "温馨提示",
      msg: "您确认要退出登录吗?",
      cancel: "取消",
      confirm: "确认",
    })
  })

  build() {
  ......
    Button('自定义弹窗')
      .onClick(() => {
        this.dialogController.open()
      })
  ......
  }
}

运行效果:

demo2

有童鞋就问了,为什么不把属性dialogController收到封装控制类里去呢?哥,我也想啊,鸿蒙不让啊(它会让你报错,跑不起来)

来看下官方文档说明:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2064322.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

新加坡门店客流计数器,AI智能识别算法加持,精准完成统计分析

在数字化转型的大潮下,零售业正经历着前所未有的变革。为了更好地理解顾客行为并优化店铺运营,新加坡的零售门店开始采用搭载AI智能识别算法的客流计数器系统。这套系统不仅能够精准统计顾客流量,还能提供深入的分析报告,帮助商家…

tcp 和udp通信

一.recvfrom recvfrom函数是一个系统调用,用于从套接字接收数据。该函数通常与无连接的数据报服务(如 UDP)一起使用,但也可以与其他类型的套接字使用。与简单的 recv() 函数不同,recvfrom() 可以返回数据来源的地址信息…

“肯将玉钳作双戟,一舞天下定乾坤。”记唐铎《墨龙图》之中的笔墨画意

唐铎,1957 年生于北京,国家一级美术师,曾先后师从于刘文西、黄申发老师,原名唐京鸣,京城人士,取其名,不鸣则已,一鸣惊人之意,学画三十余年,专注于齐派虾蟹&am…

算法工程师第四十四天(99. 岛屿数量 深搜 99. 岛屿数量 广搜 100.岛屿的最大面积 )

参考文献 代码随想录 一、岛屿数量 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,你需要计算岛屿的数量。岛屿由水平方向或垂直方向上相邻的陆地连接而成,并且四周都是水域。你可以假设矩阵外均被水包…

Android 安卓Compose软键盘和Activity页面的协调处理问题

文章目录 问题展示1、输入框展示不完整,且布局被顶出屏幕外2、输入框被软键盘完全覆盖 解决方案最终演示 问题展示 1、输入框展示不完整,且布局被顶出屏幕外 这是默认处理的样式 2、输入框被软键盘完全覆盖 当在AndroidManifest.xml Activity标签上加…

天龙八部万象归一第8版单机安装教程+GM工具+虚拟机一键端

今天给大家带来一款单机游戏的架设:天龙八部万象归一第8版。 另外:本人承接各种游戏架设(单机联网) 本人为了学习和研究软件内含的设计思想和原理,带了架设教程仅供娱乐。 教程是本人亲自搭建成功的,绝对…

火影忍者2——漩涡鸣人(仙人模式)篇

老规矩,谈火影~ 火影忍者 之—— 漩涡鸣人(仙人模式)篇 众所周知,鸣仙是一个早期的A忍,技能破坏力贼大,一般遇到鸣仙(除非我用了青水神卡)我是直接退的 普攻 一技能 螺旋丸 普…

深信服应届生客户经理面试经验分享

吉祥知识星球http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247485367&idx1&sn837891059c360ad60db7e9ac980a3321&chksmc0e47eebf793f7fdb8fcd7eed8ce29160cf79ba303b59858ba3a6660c6dac536774afb2a6330#rd 《网安面试指南》http://mp.weixin.qq.com/s?…

如何使用mmdetection训练实例分割模型?

安装 anoconda 从官方网站下载并安装。 配置环境 conda create --name openmmlab python3.8 -y conda activate mmdet 安装 PyTorch 注意:这个步骤很关键,否则后面会出问题。一定要确保自己电脑当前安装和配置的cuda版本。 使用命令:nvcc …

3.1 I-pipe四行启动代码

Interrupt Pipeline系列文章大纲-CSDN博客 I-pipe的启动代码位于init/main.c: start_kernel函数中。可以看到代码提交是集中在patch: genirq: add generic I-pipe core (8f933b57) 提交 xenomai / ipipe-arm64 GitLab (denx.de),主要是四行: &#x…

stm32—SPI

1. SPI SPI (Serial Peripheral Interface):是由美国摩托罗拉公司(Motorala)最先推出的一种同步全双工串行传输规范,也是一种单片机外设芯片串行扩展接口 SPI 接口主要应用在 EEPROM,FLASH,实时时钟, AD转换器&#xf…

ORM底层的原理

2.3.面试题3:请介绍什么是ORM思想: a.什么是ORM: 1.所谓的ORM是Dao层的一种思想,意思就是对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping…

【回文数判断】输入一个5位数,判断它是不是回文数

输入一个5位数&#xff0c;判断它是不是回文数。例如12321是回文数&#xff0c;个位和万位相同&#xff0c;十位与千位相同 使用C语言实现&#xff0c;具体代码&#xff1a; #include<stdio.h>int main(){int a,b,c,d,x;printf("输入一个5位数&#xff1a;")…

ACCESS 注入实战

简介 Access数据库注入攻击是一种常见的网络安全&#xff0c;通过注入SQL代码来获取未授权的数据访问权限。这种攻击利用了应用程序与数据库之间的交互漏洞&#xff0c;攻击者通过输入特定的SQL代码片段来操纵数据库查询&#xff0c;从而绕过应用程序的安全机制&#xff0c;获取…

中移动集团SRE人员能力提升培训圆满结课

前言&#xff1a; ​在数字化转型的浪潮中&#xff0c;中移动作为通信行业的领军企业&#xff0c;面临着日益复杂的运维挑战。SRE&#xff08;Site Reliability Engineering&#xff09;作为一种新兴的运维理念&#xff0c;为中移动提供了解决这些问题的新思路。2024年7月下旬…

OpenCV几何图像变换(7)重映射函数 remap()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 应用一个通用的几何变换到图像上。 remap 函数使用指定的地图对源图像进行变换&#xff1a; dst ( x , y ) src ( m a p x ( x , y ) , m a p …

VulnStack2-主机不出网-黄金票据-SID History

网络结构 kali192.168.20.145DC10.10.10.10PC192.168.20.201/10.10.10.201WEB192.168.20.80/10.10.10.80 WEB登录时&#xff0c;切到V1.3快照 且不登录默认用户 开启weblogic服务 漏洞利用 访问Weblogic默认的console路由http://192.168.20.80:7001/console 直接用工具打一…

深信服研发面试经验分享

吉祥知识星球http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247485367&idx1&sn837891059c360ad60db7e9ac980a3321&chksmc0e47eebf793f7fdb8fcd7eed8ce29160cf79ba303b59858ba3a6660c6dac536774afb2a6330#rd 《网安面试指南》http://mp.weixin.qq.com/s?…

新手友好:易于上手的10款项目管理工具推荐

国内外主流的 10 款轻量级项目管理软件对比&#xff1a;PingCode、Worktile、Coding、致远OA、Gitee、Wrike、ClickUp、Notion、Airtable、Basecamp。 在快节奏的工作环境中&#xff0c;有效的项目管理是成功的关键&#xff0c;尤其是对于资源有限的小型团队和初创公司而言。轻…

golang实现一个简单的rpc框架

前言 RPC在分布式系统中经常使用&#xff0c;这里写一个简单的demo实践一下。 code 先生成 go.mod 文件 go mod init rpc-try01定义方法 package model// Args 是 RPC 方法的参数结构体 type Args struct {A, B int }// Arith 定义了一个简单的算术服务 type Arith struct{…