鸿蒙HarmonyOS-Navagation基本用法
Navagation基本用法
Navigation组件是路由导航的根视图容器,一般作为Page页面的根容器使用,其内部默认包含了标题栏,内容栏和公工具栏,其中内容区默认首页显示导航内容(Navigation的子组件)或非首页显示(NavDestination的子组件),首页和非首页通过路由进行切换
- 使用Navigation跳转的组件不需要再使用Entry来修饰,普通组件即可
- Navigation是一个导航组件,API9和API11的使用官方推荐方式各不相同
1. Navagation API9的用法-(Navigation-NavRouter-(其他组件+NavDestination的用法))
1. 1导航组件层次关系
| 组件 | 作用 | 层级规则 |
|---|---|---|
Navigation | 管理所有导航页面的根容器 | 必须包含多个 NavRouter |
NavRouter | 定义一个跳转入口 | 必须配对 NavDestination |
NavDestination | 目标页面内容 |
**1. **2 按钮覆盖问题
- 代码现象:
跳转B覆盖跳转A - 根本原因:
在NavRouter内部放置多个直接同级组件时,仅最后一个组件会被渲染。 - ArkUI规则:
一个NavRouter只能关联 一个触发元素 (如Button),如需多个跳转需使用多个NavRouter。
1.3 代码案例
@Entry
@Component
struct TestNavgationAPI9 {build() {Navigation() {// --------------------- 第一跳转入口 ---------------------NavRouter() { // ✅ 触发元素Button('跳转A')Button('跳转B') //放置的第二个界面会覆盖第一个//要跳转的界面NavDestination() { // ✅ 目标页面AImage($r('app.media.Coverpeople')).width(50).aspectRatio(1)// --------------------- 第二跳转入口 ---------------------NavRouter() { // ✅ 触发元素//第一个组件就是跳转的// --------------------- 第二跳转入口 ---------------------Text('我跳转啦') // ✅ 目标页面BNavDestination() {Text('第三个界面') // ✅ 目标页面C}}}}}.height('100%').width('100%')}
}
1.4 效果展示

2.Navagation 10的用法
2.1 路由栈自主管理
-
NavPathStack核心方法:
pushPath() // 压入新页面(保留前页) replacePath() // 替换当前页面(销毁前页) pop() // 回到上一页
2.2 页面加载控制
navDestination(builder)
通过Builder函数动态渲染路由目标:
- 函数动态渲染路由目标:
.navDestination(this.navDesBuilder) // 动态路由映射
@Builder
navDesBuilder(name: string) {if (name === "pageTwo") {NavgationChild02() // 根据 name 组装对应页面}
}
2.3 跨组件通信
-
@Provide与@Consume装饰器// 父级定义提供值 @Provide navPathStack: NavPathStack = new NavPathStack() // 子组件自动获取 @Consume navPathStack: NavPathStack无需显式传递,自动向下注入。
2.4 实现步骤
1. 自己管理页面栈 创建一个页面栈 (用@Provide修饰,方便跨组件使用)
@ProvidenavPathStack: NavPathStack = new NavPathStack()
2.将创建的页面栈实例传递给主界面
ps:这一步还是蛮关键的,很多页面不展示就是这个原因
Navigation(this.navPathStack) {Text('这是第一页-首页')Button('去下一页').onClick(() => {this.navPathStack.pushPath({name: 'pageOne'})})}.height('100%').width('100%')
3.通过 Builder 函数动态渲染路由目标
1. 先创建一个自定义Builder
@BuildermyNavPathStackBuilder(name: string) {//根据传入的名字区渲染对应的页面if (name === 'pageOne') {Children01()} else if (name === 'pageTwo') {Children02()} else if (name === 'pageThree') {Children03()}}
2. 传入Builder
.navDestination(this.navDesBuilder)
-
不需要加括号,这里有个底层原因
- ArkUI 的
navDestination机制
- 设计逻辑:框架需要在导航时动态调用构建函数生成页面。若传递this.navDesBuilder()则:
- 代码执行时立即运行该函数(而非按需调用)
- 返回结果可能为
void或非组件类型,导致渲染异常。
@Builder函数的特性
-
延迟执行:
@Builder定义的 UI 编译时会转为独立闭包代码块 -
调用时机:由 导航框架 在需要时(如
pushPath)根据name参数触发构建this.navPathStack.pushPath({ name: 'pageTwo' }); // ▶️ 此时 ArkUI 内部通过 `.navDestination` 关联的 Builder 按需执行
- ArkUI 的
3.跳转的实现
- 通过点击事件调用当前
navPathStack实例pushPath方法 - 传入你要跳转页面的名字,进行跳转
Button('去下一页').onClick(() => {this.navPathStack.pushPath({name: 'pageOne'})})
4.子界面的定义
@Component
struct Children01 {//接收主界面传递过来的页面栈@Consume navPathStack: NavPathStackbuild() {NavDestination() {Column({ space: 5 }) {Text('这是我从主页跳转的第一个界面').fontSize(24).fontWeight(500)Button('跳转到第二个页面去').onClick(() => {this.navPathStack.pushPath({name: 'pageTwo'})})}}}
}
@Component
struct Children02 {@ConsumenavPathStack: NavPathStackbuild() {NavDestination() {Column({ space: 5 }) {Text('这是我从主页跳转的第二个界面').fontSize(24).fontWeight(500)Button('跳转到第三个页面去').onClick(() => {this.navPathStack.pushPath({name: 'pageThree'})})}}}
}@Component
struct Children03 {@ConsumenavPathStack: NavPathStackbuild() {NavDestination() {Column() {Text('这是我从主页跳转的第三个界面').fontSize(24).fontWeight(500)}}}
}
5.效果展示

3.NavagationAPI10使用的补充内容
3.1 常见的API
| 配置组合 | 代码示例 | 效果描述 |
|---|---|---|
| 默认状态 | Navigation() .title('主标题') | 标题栏显示 “主标题”,采用 Free 模式 |
| 精简模式+隐藏标题 | Navigation() .titleMode(NavigationTitleMode.Mini) .hideTitleBar(true) | 标题栏完全不可见 |
| 子页面独立配置 | NavDestination() .title('子页标题') .hideTitleBar(true) |
3.2 传参获取参数的实现
1.定义数据结构
interface hobby {name: string,hobby: string
}
2.即将跳转页面传入参数
NavDestination() {Column({ space: 5 }) {Text('这是我从主页跳转的第二个界面').fontSize(24).fontWeight(500)Button('跳转到第三个页面去').onClick(() => {this.navPathStack.pushPath({name: 'pageThree',param: { name: '猫猫球', hobby: '喜欢玩毛线球' } as hobby})})}}
3.跳转的页面接收数据
@Component
struct Children03 {@Statehobby: hobby[] = [] as hobby[]@ConsumenavPathStack: NavPathStackaboutToAppear(): void {this.hobby = this.navPathStack.getParamByName('pageThree') as hobby[]promptAction.showToast({message: JSON.stringify(this.hobby)})}build() {NavDestination() {Column() {Text('这是我从主页跳转的第三个界面')Text('这是我获取的数据')Text(this.hobby[0].name)Text(this.hobby[0].hobby).fontWeight(500)}}}
}
4.效果展示

相关文章:
鸿蒙HarmonyOS-Navagation基本用法
Navagation基本用法 Navigation组件是路由导航的根视图容器,一般作为Page页面的根容器使用,其内部默认包含了标题栏,内容栏和公工具栏,其中内容区默认首页显示导航内容(Navigation的子组件)或非首页显示&am…...
第16章 直接定址表
目录 16.1 描述了单元长度的标号16.2 在其它段中使用数据标号16.3 直接定址表16.4 程序入口地址的直接定址表实验16 编写包含多个功能子程序的中断例程 16.1 描述了单元长度的标号 assume cs:code code segment a db 1,2,3,4,5,6,7,8 b dw 0 start: mov si,0 mov cx…...
【AI深度学习网络】卷积神经网络(CNN)入门指南:从生物启发的原理到现代架构演进
深度神经网络系列文章 【AI深度学习网络】卷积神经网络(CNN)入门指南:从生物启发的原理到现代架构演进【AI实践】基于TensorFlow/Keras的CNN(卷积神经网络)简单实现:手写数字识别的工程实践 引言 在当今…...
江科大51单片机笔记【10】蜂鸣器播放提示器音乐(下)
一、蜂鸣器播放提示器 这里我们要用Key,Delay,Nixie模块 并且把Nixie.c函数里的这两句注释,因为之前是动态显示,延时后马上清零,现在是静态显示,所以需要把他注释掉 // Delay(1); // P00x00; 先验…...
Milvus JSON数据存储优化方案
无论是json数据还是string/varchar 类型数据,其长度都不能超过65536,这是根本,不像ES的text类型数据一样,可以无限长。 总结 数据类型适用场景最大长度STRINGMilvus <2.2.x 的短文本(<65KB)隐式 ≈65,535 字节VARCHAR(N)Milvus ≥2.2.x 的文本显式 N≤65,535 字符…...
MySQL 数据库连接池爆满问题排查与解决
目录 MySQL 数据库连接池爆满问题排查与解决 一、问题影响 二、问题确认 三、收集信息 四、SQL 语句分析 五、应用层代码分析 六、连接池配置检查 七、监控工具使用 八、案例分析 在实际的应用开发中,我们可能会遇到 MySQL 数据库连接池爆满的情况。这种情…...
PyTorch深度学习的梯度消失和梯度爆炸的识别、解决和最佳实践
通过结合梯度监控、网络架构改进和优化策略,可以有效应对梯度消失/爆炸问题。建议在模型开发初期就加入梯度监控机制,这有助于快速定位问题层。对于超深网络(>50层),建议优先考虑使用预激活残差结构(Res…...
Nginx1.19.2不适配OPENSSL3.0问题
Nginx 1.19.2 是较老的版本,而 Nginx 1.21 版本已经适配 OpenSSL 3.0,所以建议 升级 Nginx 到 1.25.0 或更高版本: wget http://nginx.org/download/nginx-1.25.0.tar.gz tar -xzf nginx-1.25.0.tar.gz cd nginx-1.25.0 ./configure --prefix…...
蓝桥杯 Excel地址
Excel地址 题目描述 Excel 单元格的地址表示很有趣,它使用字母来表示列号。 比如, A 表示第 1 列, B 表示第 2 列, Z 表示第 26 列, AA 表示第 27 列, AB 表示第 28 列, BA 表示第 53 列&#x…...
免费pdf格式转换工具
基本功能 - 支持单文件转换和批量转换两种模式 - 内置PDF文件预览功能 - 支持8种常见格式转换:Word、Excel、JPG/PNG图片、HTML、文本、PowerPoint和ePub 单文件转换功能 - 文件选择:支持浏览和选择单个PDF文件 - 输出位置:可自定义设置输出…...
I²C总线应用场景及1.8V与3.3V电压选择
以下是关于IC总线应用场景及1.8V与3.3V电压选择的详细分析: 一、IC总线的典型应用场景 1. 板内通信(主要场景) 描述:IC 最初设计是为电路板(PCB)上的芯片间短距离通信,尤其适用于集成度高的系统。典型器件: 传感器模块(如温湿度传感器BME280)。存储芯片(如EEPROM 2…...
css错峰布局/瀑布流样式(类似于快手样式)
当样式一侧比较高的时候会自动换行,尽量保持高度大概一致, 例: 一侧元素为5,另一侧元素为6 当为5的一侧过于高的时候,可能会变为4/7分部dom节点 如果不需要这样的话删除样式 flex-flow:column wrap; 设置父级dom样…...
Deepseek中的MoE架构的改造:动态可变参数激活的MoE混合专家架构(DVPA-MoE)的考虑
大家好,我是微学AI,今天给大家介绍一下动态可变参数激活MoE架构(Dynamic Variable Parameter-Activated MoE, DVPA-MoE)的架构与实际应用,本架构支持从7B到32B的等多档参数动态激活。该架构通过细粒度难度评估和分层专家路由,实现“小问题用小参数,大问题用大参数”的精…...
docker-compose Install reranker(fastgpt支持) GPU模式
前言BGE-重新排名器 与 embedding 模型不同,reranker 或 cross-encoder 使用 question 和 document 作为输入,直接输出相似性而不是 embedding。 为了平衡准确性和时间成本,cross-encoder 被广泛用于对其他简单模型检索到的前 k 个文档进行重…...
doris: MySQL
Doris JDBC Catalog 支持通过标准 JDBC 接口连接 MySQL 数据库。本文档介绍如何配置 MySQL 数据库连接。 使用须知 要连接到 MySQL 数据库,您需要 MySQL 5.7, 8.0 或更高版本 MySQL 数据库的 JDBC 驱动程序,您可以从 Maven 仓库下载最新或指定版本的…...
JVM参数调整
一、内存相关参数 1. 堆内存控制 -Xmx:最大堆内存(如 -Xmx4g,默认物理内存1/4)。-Xms:初始堆内存(建议与-Xmx相等,避免动态扩容带来的性能波动)。-Xmn:新生代大小&…...
【DeepSeek问答】访问QStandardItemModel::index(r,c)获取的空索引导致程序崩溃
好的,我现在来仔细思考一下用户的问题。用户在使用QStandardItemModel的setItem方法时,调用了setItem(4,6,item),也就是在第4行第6列的位置设置了一个item。然后他们尝试通过index(3,6)来获取这个位置的项目,想知道会有什么后果。…...
基于websocket的多用户网页五子棋 --- 测试报告
目录 功能测试自动化测试性能测试 功能测试 1.登录注册页面 2.游戏大厅页面 3.游戏房间页面 自动化测试 1.使用脑图编写web自动化测试用例 2.创建自动化项目,根据用例通过selenium来实现脚本 根据脑图进行测试用例的编写: 每个页面一个测试类&am…...
在 macOS 上使用 CLion 进行 Google Test 单元测试
介绍 Google Test(GTest)是 Google 开源的 C 单元测试框架,它提供了简单易用的断言、测试夹具(Fixtures)和测试运行机制,使 C 开发者能够编写高效的单元测试。 本博客将介绍如何在 macOS 上使用 CLion 配…...
深度解码!清华大学第六弹《AIGC发展研究3.0版》
在Grok3与GPT-4.5相继发布之际,《AIGC发展研究3.0版》的重磅报告——这份长达200页的行业圣经,不仅预测了2025年AI技术爆发点,更将「天人合一」的东方智慧融入AI伦理建构,堪称数字时代的《道德经》。 文档:清华大学第…...
【论文笔记】Attentive Eraser
标题:Attentive Eraser: Unleashing Diffusion Model’s Object Removal Potential via Self-Attention Redirection Guidance Source:https://arxiv.org/pdf/2412.12974 收录:AAAI 25 作者单位:浙工商,字节&#…...
97k倍区间
97k倍区间 ⭐️难度:中等 🌟考点:暴力,2017省赛 📖 📚 import java.util.Scanner;public class Main {static int N 100010;public static void main(String[] args) {Scanner sc new Scanner(System.…...
cursor使用经验分享(java后端服务开发向)
前言 cursor是一款基于vscode,并集成AI能力的代码编辑器,其功能包括但不限于代码生成及补全、AI对话(能够直接将代码环境作为上下文)、即时应用建议等等,是一款面向未来的代码编辑器。 对于vscode,最先想…...
SpringBoot3—场景整合:AOT
一、AOT与JIT AOT:Ahead-of-Time(提前编译):程序执行前,全部被编译成机器码 JIT:Just in Time(即时编译): 程序边编译,边运行; 编译:源代码&am…...
蓝桥与力扣刷题(蓝桥 数字三角形)
题目: 上图给出了一个数字三角形。从三角形的顶部到底部有很多条不同的路径。对于每条路径,把路径上面的数加起来可以得到一个和,你的任务就是找到最大的和(路径上的每一步只可沿左斜线向下或右斜线向下走)。 输入描述…...
蓝桥试题:传球游戏(二维dp)
一、题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏。这次,老师带着同学们一起做传球游戏。 游戏规则是这样的:n 个同学站成一个圆圈,其中的一个同学手里拿着一个球,当老师吹哨子时开始传球࿰…...
游戏引擎学习第138天
仓库:https://gitee.com/mrxiao_com/2d_game_3 资产:game_hero_test_assets_003.zip 发布 我们的目标是展示游戏运行时的完整过程,从像素渲染到不使用GPU的方式,我们自己编写了渲染器并完成了所有的工作。今天我们开始了一些新的内容&#…...
Lab 3 Page Table
题目链接 我的问题: 1 每个进程的kernel stack是干啥的来着?在何时初始化的? 题目2:A kernel page table per process (hard) 1 一些题目要求 Your first job is to modify the kernel so that every process uses its own c…...
嵌入式学习L5D2-exec函数族和守护进程
exec函数族1 下面那个加了p环境变量就不用那个了。 输出的是系统 exec函数族2 后面不执行了 第二个参数瞎写也可以,但是要填 这里是说不想被替换,就在子进程里面执行这个。 守护进程概念 后台进程 守护进程是后台进程 一个fork了一个进程ÿ…...
洛谷P1091
题目如下 思路 谢谢观看...
