HarmonyOS鸿蒙开发实战(5.0)自定义全局弹窗实践

鸿蒙HarmonyOS开发实战往期文章必看:

HarmonyOS NEXT应用开发性能实践总结

最新版!"非常详细的" 鸿蒙HarmonyOS Next应用开发学习路线!(从零基础入门到精通)

非常详细的" 鸿蒙HarmonyOS Next应用开发学习路线!(从零基础入门到精通)


介绍

全局状态保留能力弹窗一种很常见的能力,能够保持状态,且支持全局控制显隐状态以及自定义布局。使用效果参考评论组件

效果图预览

使用说明

使用案例参考短视频案例

  1. 首先程序入口页对全局弹窗初始化,使用GlobalStateDialogManager.getGlobalStateDialogNodeController().setUIContext(this.getUIContext())。
  2. 在全局入口页设置弹窗位置GlobalStateDialog()。
  3. 在需要使用弹窗的页面引入GlobalStateDialogManager,使用operateGlobalStateDialog函数对弹窗显隐及内容布局进行配置,配置项参考GlobalStateDialogConfig

实现思路

  1. 使用显隐控制来实现弹窗的状态保留能力,使用NodeContainer来动态操作弹窗的布局以及内容。源码参考GlobalStateDialog.ets

    /**

    • 全局状态保留能力弹窗组件
      */
      @Component
      export struct GlobalStateDialog {
      @StorageProp('isShowGlobalStateDialog') isShowGlobalStateDialog: boolean = false;

    build() {
    Column() {
    、、、
    // 弹窗的布局与内容,使用NodeContainer提前占位
    NodeContainer(GlobalStateDialogManager.getGlobalStateDialogNodeController())
    }
    .visibility(this.isShowGlobalStateDialog ? Visibility.Visible : Visibility.Hidden)
    .backgroundColor(r('app.color.ohos_global_state_dialog_background_color')) .height(r('app.string.ohos_global_state_dialog_sixty_percent'))
    .borderRadius({
    topLeft: r('app.integer.ohos_global_state_dialog_number_10'), topRight: r('app.integer.ohos_global_state_dialog_number_10')
    })
    .width($r('app.string.ohos_global_state_dialog_hundred_percent'))
    }
    }

    /**

    • 全局状态保留能力弹窗控制器,对外提供fillGlobalStateDialog函数来操作弹窗的布局与内容
      */
      export class GlobalStateDialogNodeController extends NodeController {
      private uiContext: UIContext | null = null;
      private rootNode: BuilderNode<[ESObject]> | null = null;
      private wrapBuilder: WrappedBuilder<[ESObject]> | null = null;
      private params: ESObject;

    setUIContext(uiContext: UIContext) {
    this.uiContext = uiContext;
    }

    /**
    * 填充全局状态保留能力弹窗的布局以及内容
    * @param wrapBuilder 布局
    * @param params 内容
    */
    fillGlobalStateDialog(wrapBuilder: WrappedBuilder<[ESObject]>, params: ESObject) {
    this.wrapBuilder = wrapBuilder;
    this.params = params;
    this.refreshNode();
    }

    makeNode(uiContext: UIContext): FrameNode | null {
    if (this.rootNode != null) {
    // 返回FrameNode节点
    return this.rootNode.getFrameNode();
    }
    // 返回null控制动态组件脱离绑定节点
    return null;
    }

    refreshNode() {
    if (!this.uiContext) {
    return;
    }
    // 创建节点,需要uiContext
    this.rootNode = new BuilderNode(this.uiContext)
    // 创建组件
    this.rootNode.build(this.wrapBuilder, this.params)
    this.rebuild();
    }
    }

    /**

    • 全局弹窗配置项
      */
      interface GlobalStateDialogConfig {
      isShowGlobalStateDialog?: boolean; // 显隐控制:true显示/false隐藏
      wrapBuilder?: WrappedBuilder<[ESObject]>; // 布局
      params?: ESObject; // 内容
      }

    /**

    • 管理全局弹窗
      */
      export class GlobalStateDialogManager {
      private static globalStateDialogController: GlobalStateDialogNodeController = new GlobalStateDialogNodeController();

    static getGlobalStateDialogNodeController(): GlobalStateDialogNodeController {
    return GlobalStateDialogManager.globalStateDialogController;
    }

    /**
    * 控制全局弹窗的显隐及内容布局
    * @param globalStateDialogConfig 配置全局弹窗
    */
    static operateGlobalStateDialog(globalStateDialogConfig: GlobalStateDialogConfig) {
    if (globalStateDialogConfig.isShowGlobalStateDialog !== undefined) {
    AppStorage.setOrCreate('isShowGlobalStateDialog', globalStateDialogConfig.isShowGlobalStateDialog);
    }
    if (globalStateDialogConfig.wrapBuilder) {
    GlobalStateDialogManager.globalStateDialogController.fillGlobalStateDialog(globalStateDialogConfig.wrapBuilder, globalStateDialogConfig.params);
    }
    }
    }

  2. 使用Stack堆叠能力,为全局弹窗占位,且初始化相关数据。源码参考EntryView.ets.ets

    @Entry
    @Component
    struct EntryView {
    、、、
    aboutToAppear(): void {
    、、、
    GlobalStateDialogManager.getGlobalStateDialogNodeController().setUIContext(this.getUIContext());
    、、、
    }

    build() {
    Stack() {
    、、、

    复制代码
       // 全局状态保留能力弹窗
       GlobalStateDialog()
     }
     .alignContent(Alignment.BottomEnd)
     .height('100%')
     .backgroundColor($r('app.color.main_background_color'))

    }
    }

高性能知识点

不涉及

工程结构&模块类型

复制代码
utils                             // har类型
|---component
|   |---GlobalStateDialog.ets     // 全局状态保留能力弹窗
相关推荐
繁依Fanyi15 分钟前
ImgShrink:摄影暗房里的在线图片压缩工具开发记
开发语言·前端·codebuddy首席试玩官
卓律涤20 分钟前
【找工作系列①】【大四毕业】【复习】巩固JavaScript,了解ES6。
开发语言·前端·javascript·笔记·程序人生·职场和发展·es6
梁下轻语的秋缘23 分钟前
HarmonyOS:重构万物互联时代的操作系统范式
华为·重构·harmonyos
lpfasd12326 分钟前
Flutter与Kotlin Multiplatform(KMP)深度对比及鸿蒙生态适配解析
flutter·kotlin·harmonyos
交叉编译之王 hahaha39 分钟前
OpenHarmony 5.1.0 Release目录结构详细解析(3级目录)
arm开发·华为·harmonyos
Ten peaches1 小时前
Selenium-Java版(环境安装)
java·前端·selenium·自动化
心.c1 小时前
vue3大事件项目
前端·javascript·vue.js
交叉编译之王 hahaha1 小时前
RK3568-鸿蒙5.1与原生固件-扇区对比分析
华为·harmonyos
姜 萌@cnblogs1 小时前
【实战】深入浅出 Rust 并发:RwLock 与 Mutex 在 Tauri 项目中的实践
前端·ai·rust·tauri
蓝天白云下遛狗1 小时前
google-Chrome常用插件
前端·chrome