当前位置: 首页 > news >正文

HarmonyOS 中 Navigation 组件的应用困境与应对策略

HarmonyOS 中 Navigation 组件的应用困境与应对策略

引言

在 HarmonyOS 移动应用开发领域,Navigation 组件扮演着关键角色,其主要功能在于实现页面及组件内部的页面跳转,同时支持在不同组件间传递跳转参数,极大地提升了对不同页面访问与复用的便捷性。通常,Navigation 作为路由导航的根视图容器,被广泛应用于页面(@Entry)的根容器构建。若开发者期望深入了解 Navigation 的具体使用方法,可参考以下链接:在哪里?在哪里!设置到底在哪里!!!HarmonyOS 移动应用开发 —— 设置组件导航(Navigation 组件、Tabs 组件实现页面导航)_harmony navigation tabs - CSDN 博客。

基于 Navigation 组件导航的特性,华为官方精心设计了一套基于 Navigation 的路由设计方案,旨在实现多模块路由管理以及模块间的有效解耦。在此基础上,通过动态注册路由的方式,成功解决了页面加载多个 UI 组件时启动速度变慢的问题。如需深入探究该方案的详细使用方法,可查阅:《应用导航设计:裂变式路由风暴来袭》——HarmonyOS 开发项目时的 Navigation 路由奇妙使用 - CSDN 博客。

然而,需要注意的是,Navigation 以 @Entry 作为页面的根容器。当项目采用分层架构进行构建时,从软件工程的最佳实践角度出发,@Entry 页面不应包含 UI 渲染相关的逻辑与业务。但由于 Navigation 对根容器的设定,使得该页面无法从 Navigation 的页面栈中剔除,这就导致了潜在的应用开发困境。

示例

以一个常见的 APP 场景为例,假设该 APP 的 @Entry 入口页面为闪屏页。闪屏页通常仅在用户启动 APP 时进行渲染,当用户成功进入 APP 主界面后,若不慎误触返回按键,由于闪屏页作为 @Entry 页面且是 Navigation 的根容器,依据其机制无法被销毁,此时用户可能会直接被导航回闪屏页。这种情况显然违背了良好用户体验的设计原则,对用户的操作流畅性与沉浸感造成了负面影响。

解决方案

状态控制与布局组合

// 状态定义
@State showSplash: boolean = true
@State mainPathStack: NavPathStack = new NavPathStack()

// 组合布局
Column() {
    if (this.showSplash) {
        SplashScreen() // 条件渲染
    } else {
        Navigation(this.mainPathStack) { // 路由容器
            Row() { 
                Button('退出').onClick(() => /*...*/)
                Button('取消').onClick(() => /*...*/)
            }.height('10%')
        }
    }
}
  • 通过定义showSplash状态变量,明确表示当前是否显示闪屏页。

  • 依据showSplash的状态判断,动态渲染不同的用户界面。若showSplash为真,则渲染闪屏页;若为假,则进入 Navigation 的导航容器。

  • 将此页面作为根页面,设置提示按钮,当用户触发相关操作时,提示用户是否确定退出应用。这种设计有效避免了因误触导致闪屏页重新渲染或出现空容器的不良情况,提升了用户操作的容错性。

全局退出确认弹窗

aboutToDisappear(): void {
    this.context.terminateSelf();
}
  • 该方案通过调用params.context.terminateSelf()方法,实现直接退出应用的功能。

  • 但由于组件生命周期中的aboutToDisappear函数无法阻止组件销毁,这与 @Entry 的onBackStress回调机制存在差异,导致无法在组件销毁时阻止并弹出提示框。因此,在实际应用中,该方法仅能在闪屏页跳转后的第一个组件被销毁时,直接关闭整个 APP。然而,这种方式在用户误触的情况下,极易引发不佳的用户体验,故在实际项目开发中并不推荐使用。

相关文章:

  • 进程优先级和进程切换 ─── linux第12课
  • Windows逆向工程入门之MASM数据结构使用
  • ssm整合项目实现基础查询功能
  • 整数对最小和
  • 代数结构—笔记
  • 逻辑运算 | 位运算
  • 计算机网络:Socket网络编程 Udp与Tcp协议 第一弹
  • 基于SpringBoot+Vue的电影订票及评论网站的设计与实现(源码+SQL脚本+LW+部署讲解等)
  • Java中String,StringBuffer,StringBuilder详解
  • 一文熟悉新版llama.cpp使用并本地部署LLAMA
  • [Windows] 免费电脑控制手机软件 极限投屏_正式版_3.0.1 (QtScrcpy作者开发)
  • Python利用pyobdc和tkinter框架连接数据库2-保存配置文件
  • 最新最详细的配置Node.js环境教程
  • shell脚本编程实践第6天
  • 【星云 Orbit • STM32F4】06. 串口密码:USART 数据传递
  • 论coding能力 new bing 对比 chatgpt
  • 安当防火墙登录安全解决方案:零信任认证+国密证书+动态口令构建全方位身份安全屏障
  • c语言中return 数字代表的含义
  • 2024 ChatGPT大模型技术场景与商业应用视频精讲合集(45课).zip
  • Playwright的测试定义为什么不写在测试类定义内部
  • 《歌手2025》公布首发阵容,第一期就要淘汰一人
  • “80后”德州市接待事务中心副主任刘巍“拟进一步使用”
  • 梅花奖在上海丨陈丽俐“婺剧折戏专场”:文戏武做,武戏文唱
  • 比特币挖矿公司GRYP股价涨超171%:将与特朗普儿子创设的公司合并
  • 我国7名优秀护理工作者荣获第50届南丁格尔奖
  • 何立峰:中方坚定支持多边主义和自由贸易,支持世界贸易组织在全球经济治理中发挥更大作用