0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

HarmonyOS开发案例:【弹窗使用】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-04-25 17:44 次阅读

介绍

本篇Codelab主要基于dialog和button组件,实现弹窗的几种自定义效果,具体效果有:

  1. 警告弹窗,点击确认按钮弹窗关闭。
  2. 确认弹窗,点击取消按钮或确认按钮,触发对应操作。
  3. 加载弹窗,展示加载中效果。
  4. 提示弹窗,支持用户输入内容,点击取消和确认按钮,触发对应操作。
  5. 进度条弹窗,展示进度条以及百分比。

相关概念

  • [dialog组件]:自定义弹窗容器组件。
  • [button组件]:按钮组件。

环境搭建

软件要求

  • [DevEco Studio]版本:DevEco Studio 3.1 Release及以上版本。
  • OpenHarmony SDK版本:API version 9及以上版本。

硬件要求

  • 开发板类型:[润和RK3568开发板]。
  • OpenHarmony系统:3.2 Release及以上版本。

环境搭建

完成本篇Codelab我们首先要完成开发环境的搭建,本示例以RK3568开发板为例,参照以下步骤进行:

  1. [获取OpenHarmony系统版本]:标准系统解决方案(二进制)。以3.2 Release版本为例:
  2. 搭建烧录环境。
    1. [完成DevEco Device Tool的安装]
    2. [完成RK3568开发板的烧录]
  3. 搭建开发环境。
    1. 开始前请参考[工具准备],完成DevEco Studio的安装和开发环境配置。
    2. 开发环境配置完成后,请参考[使用工程向导]创建工程(模板选择“Empty Ability”)。
    3. 工程创建完成后,选择使用[真机进行调测]。
    4. 鸿蒙开发指导文档:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

代码结构解读

本篇Codelab只对核心代码进行讲解,对于完整代码,我们会在gitee中提供。

├──entry/src/main/js         // 代码区
│  └──MainAbility
│     ├──common
│     │  └──images           // 图片资源
│     ├──i18n                // 国际化中英文
│     │  ├──en-US.json			
│     │  └──zh-CN.json			
│     ├──pages
│     │  └──index
│     │     ├──index.css     // 页面整体布局以及弹窗样式
│     │     ├──index.hml     // 自定义弹窗展示页面
│     │     └──index.js      // 弹窗显示关闭逻辑以及动画逻辑
│     └──app.js              // 程序入口
└──entry/src/main/resources  // 应用资源目录

`HarmonyOS与OpenHarmony鸿蒙文档籽料:mau123789是v直接拿`

搜狗高速浏览器截图20240326151450.png

构建界面

界面主要包括按钮列表页和自定义弹窗两部分,我们可以通过在dialog标签中添加自定义组件设置弹窗,具体效果如图所示:

首先搭建index.hml中的按钮页,主要包括5种常见的弹窗,分别为AlertDialog、ConfirmDialog、LoadingDialog、PromptDialog以及ProgressDialog。

< !--index.hml-- >
< div class="btn-div" >
    < button type="capsule" value="AlertDialog" class="btn" onclick="showAlert" >< /button >
    < button type="capsule" value="ConfirmDialog" class="btn" onclick="showConfirm" >< /button >
    < button type="capsule" value="LoadingDialog" class="btn" onclick="showLoading" >< /button >
    < button type="capsule" value="PromptDialog" class="btn" onclick="showPrompt" >< /button >
    < button type="capsule" value="ProgressDialog" class="btn" onclick="showProgress" >< /button >
< /div >

警告弹窗(AlertDialog)

然后在index.hml中创建AlertDialog自定义弹窗,效果如图所示:

< !-- index.hml -- >
< !-- AlertDialog自定义弹窗 -- >
< dialog id="alertDialog" class="alert-dialog" >
    < div class="dialog-div" >
        < div class="alert-inner-txt" >
            < text class="txt" >AlertDialog< /text >
        < /div >
        < div class="alert-inner-btn" >
            < button class="btn-single" type="capsule" value="Confirm" onclick="confirmClick('alertDialog')" >
            < /button >
        < /div >
    < /div >
< /dialog >

确认弹窗(ConfirmDialog)

创建ConfirmDialog自定义弹窗,效果如图所示:

< !-- index.hml -- >
< !-- ConfirmDialog自定义弹窗 -- >
< dialog id="confirmDialog" class="dialog-main" >
    < div class="dialog-div" >
        < div class="inner-txt" >
            < text class="txt" >ConfirmDialog< /text >
        < /div >
        < div class="inner-btn" >
            < button type="capsule" value="Cancel" class="btn-txt-left" onclick="cancelClick('confirmDialog')" >
            < /button >
            < button type="capsule" value="Confirm" class="btn-txt-right" onclick="confirmClick('confirmDialog')" >
            < /button >
        < /div >
    < /div >
< /dialog >

加载弹窗(LoadingDialog)

创建LoadingDialog自定义弹窗,效果如图所示:

< !-- index.hml -- >
< !-- LoadingDialog自定义弹窗 -- >
< dialog id="loadingDialog" class="low-height-dialog" >
    < div class="dialog-loading" >
        < text >Loading...< /text >
        < image class="loading-img img-rotate" id="loading-img" src="/common/images/ic_loading.svg" >< /image >
    < /div >
< /dialog >

提示弹窗(PromptDialog)

创建PromptDialog自定义弹窗,效果如图所示:

< !-- index.hml -- >
< !-- PromptDialog自定义弹窗 -- >
< dialog id="promptDialog" class="dialog-prompt" >
    < div class="dialog-div-prompt" >
        < div class="inner-txt-prompt" >
            < text class="txt" >PromptDialog< /text >
        < /div >
        < input class="prompt-input" type="password" placeholder="please enter password" >
        < /input >
        < div class="inner-btn" >
            < button type="capsule" value="Cancel" class="btn-txt-left" onclick="cancelClick('promptDialog')" >
            < /button >
            < button type="capsule" value="Confirm" class="btn-txt-right" onclick="confirmClick('promptDialog')" >
            < /button >
        < /div >
    < /div >
< /dialog >

进度条弹窗(ProgressDialog)

创建ProgressDialog自定义弹窗,效果如图所示:

< !-- index.hml -- >
< !-- ProgressDialog自定义弹窗 -- >
< dialog id="progressDialog" class="low-height-dialog" oncancel="onCancel" >
    < div class="dialog-progress-div" >
        < div class="inner-txt-progress" >
            < text class="download-txt" >Downloading...< /text >
            < text >{{ percent + '%' }}< /text >
        < /div >
        < div class="progress-div" >
            < progress class="min-progress" type="horizontal" percent="{{ percent }}" secondarypercent="50" >
            < /progress >
        < /div >
    < /div >
< /dialog >

然后在index.js中文件实现不同button的点击事件,展示对应弹窗:

// index.js
export default {
  data: {...},

  // 展示AlertDialog
  showAlert() {
    this.$element('alertDialog').show();
  },

  // 展示ConfirmDialog
  showConfirm() {
    this.$element('confirmDialog').show();
  },

  // 展示LoadingDialog
  showLoading() {
    ...
    this.animation = this.$element('loading-img').animate(frames, options);
    this.animation.play();
    this.$element('loadingDialog').show();
  },

  // 展示PromptDialog
  showPrompt() {
    this.$element('promptDialog').show();
  },

  // 展示ProgressDialog
  showProgress() {
    ...
  }
}

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HarmonyOS
    +关注

    关注

    79

    文章

    1967

    浏览量

    29997
  • OpenHarmony
    +关注

    关注

    25

    文章

    3657

    浏览量

    16128
  • 鸿蒙OS
    +关注

    关注

    0

    文章

    188

    浏览量

    4367
收藏 人收藏

    评论

    相关推荐

    TL3588-视频开发案

    TL3588-视频开发案
    的头像 发表于 01-24 16:29 646次阅读
    TL3588-视频<b class='flag-5'>开发案</b>例

    TLT507-Linux-RT应用开发案

    TLT507-Linux-RT应用开发案
    的头像 发表于 01-26 09:46 654次阅读
    TLT507-Linux-RT应用<b class='flag-5'>开发案</b>例

    3568F-视频开发案

    3568F-视频开发案
    的头像 发表于 04-12 13:51 839次阅读
    3568F-视频<b class='flag-5'>开发案</b>例

    HarmonyOS开发案例:【 自定义弹窗

    基于ArkTS的声明式开发范式实现了三种不同的弹窗,第一种直接使用公共组件,后两种使用CustomDialogController实现自定义弹窗
    的头像 发表于 05-16 18:18 1272次阅读
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>开发案</b>例:【 自定义<b class='flag-5'>弹窗</b>】

    HarmonyOS开发案例:【多种样式弹窗

    如何使用弹窗功能,实现四种类型弹窗。分别是:警告弹窗、自定义弹窗、日期滑动选择器弹窗、文本滑动选择器弹窗
    的头像 发表于 05-08 15:32 689次阅读
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>开发案</b>例:【多种样式<b class='flag-5'>弹窗</b>】

    HarmonyOS实战开发-全局弹窗封装案例

    介绍 本示例介绍两种弹窗的封装案例。一种是自定义弹窗封装成自定义组件的方式,使用一句代码即可控制显示;一种是使用子窗口的方式实现弹窗,使用一句代码即可展示。 效果预览图 使用说明 进入首页会立马
    发表于 05-08 15:51

    HarmonyOS IoT 硬件开发案例分享

    ``许思维老师HiSpark Wi-Fi IoT 开发案例分享:案例一:AHT20温湿度传感器开发、调试;案例二:oled屏驱动库移植,调试;案例三:用OLED屏播放视频,Wi-Fi 和 TCP/IP 综合应用。 ``
    发表于 10-27 17:30

    【润和直播课预告@华为开发者学院】HarmonyOS设备开发基础课程|HiSpark WiFi-IoT 智能小车套件开发案

    `【润和直播课预告@华为开发者学院】HarmonyOS设备开发基础课程|HiSparkWiFi-IoT 智能小车套件开发案例,3月18日(周四) 19:00-21:00,让你的
    发表于 03-16 15:01

    HarmonyOS应用开发-eTS-警告弹窗

    显示警告弹窗组件,可设置文本内容与响应回调。属性:名称参数类型默认值参数描述showoptions: { paramObject1| paramObject2}-定义并显示AlertDialog组
    发表于 12-22 14:16

    HarmonyOS应用开发-XPopup常用的弹窗体验

    组件名:XPopup作用:内置几种了常用的弹窗,十几种良好的动画,将弹窗和动画的自定义设计的极其简单;目前还没有出现XPopup实现不了的弹窗效果。 内置弹窗允许你使用项目已有的布局,
    发表于 05-21 11:18

    OpenHarmony应用开发之自定义弹窗

    API参考-HarmonyOS应用开发​​ CustomDialogController是自定义弹窗对应的接口,详细介绍如下: CustomDialogController(value
    发表于 09-06 14:40

    HarmonyOS Codelab 样例 一弹窗基本使用

    dialog组件:自定义弹窗容器组件。 button组件:按钮组件。 完整示例 gitee源码地址 源码下载 弹窗基本使用(JS).zip 二、环境搭建 我们首先需要完成HarmonyOS
    发表于 09-19 18:40

    许思维老师HarmonyOS IoT硬件开发案例分享

    许思维老师HiSpark Wi-Fi IoT 开发案例分享:案例一:AHT20温湿度传感器开发、调试;案例二:oled屏驱动库移植,调试;案例三:用OLED屏播放视频,Wi-Fi 和 TCP/IP 综合应用。
    发表于 10-29 10:39 39次下载
    许思维老师<b class='flag-5'>HarmonyOS</b> IoT硬件<b class='flag-5'>开发案</b>例分享

    华为开发者分论坛HarmonyOS学生公开课-OpenHarmony Codelabs开发案

    2021华为开发者分论坛HarmonyOS学生公开课-OpenHarmony Codelabs开发案
    的头像 发表于 10-24 11:25 1881次阅读
    华为<b class='flag-5'>开发</b>者分论坛<b class='flag-5'>HarmonyOS</b>学生公开课-OpenHarmony Codelabs<b class='flag-5'>开发案</b>例

    RK3568---NPU开发案

    RK3568---NPU开发案
    的头像 发表于 01-19 13:50 828次阅读
    RK3568---NPU<b class='flag-5'>开发案</b>例