页面路由

官方不推荐使用页面路由,这里仅做简单介绍。

页面路由用于标识 @Entry 注解的页面间的跳转。

包引入

import { router } from'@kit.ArkUI';

页面跳转

  1. router.pushUrl 目标页面不会替换当前页,而是压入页面栈
  2. router.replaceUrl 目标页面会替换当前页,并销毁当前页

Router模块提供了两种实例模式,分别是Standard和Single,决定了目标url是否会有对应多个实例

//无参数跳转
router.replaceUrl({
url: 'pages/PageA' // 目标url
}, router.RouterMode.Standard, (err) => {
if (err) {
console.error(`${err.code}, ${err.message}`);
return;
}
console.info('succeeded.');
})
//携带参数跳转
class DataModel {
name: string = ""
age: number = 0;
}
toPageA() {
let params: DataModel = {
name: "张三",
age: 20,
}
router.pushUrl({
url: "pages/PageA",
params: params
})
}
//在目标页面获取参数
const params: DataModel = router.getParams() as DataModel;

页面返回

通过router.back 返回上一个页面或指定页面

//返回上一个页面
router.back();
//返回到指定页面
router.back({
url: 'pages/Home'
});
//返回时传递参数
router.back({
url: 'pages/Home',
params: {
info: 'back parmas'
}
});
//返回参数获取,在返回目标页面的OnPageShow中获取参数
onPageShow() {
const params = this.getUIContext().getRouter().getParams() as Record<string, string>; // 获取传递过来的参数对象
if (params) {
const info: string = params.info as string; // 获取info属性的值
}
}

命名路由

@Entry({ routeName: 'pageA' })
@Component
export struct MyComponent {
build() {
……
}
} toPageA() {
router.pushNamedRoute({
name: "pageA",
})
}

组件导航(Navigation)

Navigation 是路由容器组件,一般作为首页的根容器,包括单栏(Stack)、分栏(Split)和自适应(Auto)三种显示模式。

在不同尺寸的设备上,Navigation组件能够自适应显示大小,自动切换分栏展示效果。

Navigation组件主要包含导航页(NavBar)和子页(NavDestination)。导航页由标题栏(Titlebar,包含菜单栏menu)、内容区(Navigation子组件)和工具栏(Toolbar)组成,其中导航页可以通过 hideNavBar 属性进行隐藏,导航页不存在页面栈中,导航页和子页,以及子页之间可以通过路由操作进行切换。

显示模式

单页面模式示意图



分栏模式示意图

  1. 自适应模式:NavigationMode.Auto
  2. 单页面模式:NavigationMode.Stack
  3. 分栏模式:NavigationMode.Split
Navigation() {
// ...
}
.mode(NavigationMode.Stack) //页面模式设置为单页面模式

标题栏

标题栏模式包括:Mini模式和Full模式

Mini模式示意图

Full模式示意图

菜单栏

菜单栏位于Navigation组件的右上角,通过menus属性进行设置。传递数组时,竖屏最多支持显示3个图标,横屏最多支持显示5个图标,多余的图标会被放入自动生成的更多图标。

菜单栏支持 CustomBuilder 参数,用来传入自定义布局。

工具栏

工具栏位于Navigation组件的底部,通过toolbarConfiguration属性进行设置。

工具栏支持 CustomBuilder 参数,用来传入自定义布局。

navPathStack: NavPathStack = new NavPathStack()

Navigation(this.navPathStack) {
// ...
}
.titleMode(NavigationTitleMode.Full) //设置标题栏模式
.menus([{ //设置菜单栏
value:"menu1",
icon:"resources/base/media/icon1.png",
action:()=>{ }
},{
value:"menu2",
icon:"resources/base/media/icon2.png",
action:()=>{ }
}])
.toolbarConfiguration([ //设置工具栏
{
value: "tab1",
icon: $r('app.media.scan_multiple_result'),
action:()=>{ }
},
{
value: "tab2",
icon: $r('app.media.scan_one_result'),
action:()=>{ }
},,
{
value: "tab3",
icon: $r('app.media.startIcon'),
action:()=>{ }
},
])

路由表配置

  1. 创建跳转页面入口Builder函数
@Builder
export function PageOneBuilder() {
PageOne()
} @Component
export struct PageOne {
@Consume('navPathStack') navPathStack: NavPathStack build() {
NavDestination() {
}.title("Page1")
}
}
  1. 在resources/base/profile中创建route_map.json文件,配置如下:

    name:路由名称

    pageSourceFile:目标页在保内的路径,相对src目录的相对路径

    buildFunction:跳转目标页的入口函数名称,必须以@Builder修饰

    data:应用自定义字段。可以通过配置项读取接口getConfigInRouteMap获取
{
"routerMap": [
{
"name": "PageOne",
"pageSourceFile": "src/main/ets/pages/PageOne.ets",
"buildFunction": "PageOneBuilder",
"data": {
"description" : "this is PageOne"
}
}
]
}
  1. 配置文件module.json5添加路由表配置
 {
"module" : {
"routerMap": "$profile:route_map"
}
}

路由表另一种实现方式:

  1. 创建Builder函数
  2. 通过Navigation的navDestination()方法创建路由表
@Builder
PageMap(name: string) {
if (name === "page1") {
PageOne()
} else if (name === "page2") {
PageTwo()
} else if (name === "page3") {
PageThree()
}
} Navigation(this.navPathStack) {
……
}.navDestination(this.PageMap)

页面导航

页面导航通过 NavPathStack 的相关接口实现

//跳转page1
this.navPathStack.pushPath({ name: "page1", param: "page1 param" })
this.navPathStack.pushPathByName("page1", "page1 param")
//带回调跳转,在目标页关闭后获取返回信息
this.navPathStack.pushPathByName("page1", "page1 param",(popInfo)=>{
console.log('Pop page name is: ' + popInfo.info.name + ', result: ' + JSON.stringify(popInfo.result))
})
//跳转并获取跳转结果信息
this.navPathStack.pushDestination({name:"page1",param:"page1 param"})
.then(()=>{
console.info('success');
})
.catch((err:BusinessError)=>{
console.info(`${err.code} - ${err.message}`);
}) //替换当前页面
this.navPathStack.replacePath({ name: "page1", param: "page1 param" }) //返回前一个页面
this.navPathStack.pop()
//返回到指定页面
this.navPathStack.popToName("page1") //删除栈中所有name=page1的页面
this.navPathStack.removeByName("page1")
//删除栈中指定索引的页面
this.navPathStack.removeByIndexes([1,2]) //获取page1页面的参数
this.navPathStack.getParamByName("page1")
//所有栈中索引1的页面参数
this.navPathStack.getParamByIndex(1)
//所有page1页面的索引集合
this.navPathStack.getIndexByName("page1")

子页面

子页面有容器 NavDestination 包裹,可以设置生命周期,独立的标题栏,菜单栏等属性,使用方法与navigation相同,其中mode属性可以指定页面类型。

页面类型:

  1. 标准类型:mode为NavDestinationMode.STANDARD,为默认类型,生命周期跟随其在NavPathStack页面栈中的位置变化而改变。
  2. 弹窗类型:mode为NavDestinationMode.DIALOG,显示为透明窗体,显示和消失时不会影响下层标准类型页面的显示和生命周期。

页面生命周期

Navigation作为路由容器,其生命周期承载在NavDestination组件上,以组件事件的形式开放。

● aboutToAppear和aboutToDisappear是自定义组件的生命周期

● OnAppear和OnDisappear是组件的通用生命周期

● 其余六个生命周期为NavDestination独有

@Component
export struct PageTwo {
@Consume('navPathStack') navPathStack: NavPathStack build() {
NavDestination() {
Column() {
Text("page2").geometryTransition("text2")
}.width('100%').height('100%')
}.title("Page2")
}
}

路由拦截

NavPathStack提供了setInterception方法,用于设置Navigation页面跳转拦截回调。该方法需要传入一个NavigationInterception对象。

NavigationInterception包含三个回调函数

  1. willShow:页面跳转前回调,允许操作栈,在当前跳转生效。
  2. didShow:页面跳转后回调,在该回调中操作栈会在下一次跳转生效。
  3. modeChange:Navigation单双栏显示状态发生变更时触发该回调。

    无论是哪个回调,在进入回调时页面栈都已经发生了变化。
this.navPathStack.setInterception({
willShow: (_from, _to, _operation, _animated) => {
if (typeof _to === "object") {
let target = _to as NavDestinationContext
if (target.pathInfo.name == "page1") {
target.pathStack.pop()
target.pathStack.pushPath({ name: "page2" })
}
}
}
})

本文的技术设计和实现都是基于作者工作中的经验总结,如有错误,请留言指正,谢谢。

HarmonyOS Next 入门实战 - 导航框架:页面路由、组件导航(Navigation)的更多相关文章

  1. 【DRF框架】路由组件

    视图组件涉及的路由补充: from rest_framework.viewsets import ViewSetMixin 对路由进行了重新的分发,重写了as_view() 方法,重新封装了请求方法 ...

  2. 零基础入门 实战mpvue2.0多端小程序框架

    第1章 课程快速预览(必看!!!)在这一章节中,老师讲带领你快速预览课程整体.其中,涉及到为什么要做这么一门实战课程.制作一个小程序的完整流程是怎么样的,以及如何做项目的技术选型. 第2章 30 分钟 ...

  3. 【Flutter学习】页面跳转之路由及导航

    一,概述 移动应用通常通过成为‘屏幕’或者‘页面’的全屏元素显示其内容,在Flutter中,这些元素统称为路由,它们由导航器Navigator组件管理.导航器管理一组路由Route对象,并提供了管理堆 ...

  4. 《React后台管理系统实战 :二》antd左导航:cmd批量创建子/目录、用antd进行页面布局、分离左导航为单独组件、子路由、动态写左导航、css样式相对陷阱

    一.admin页面布局及路由创建 0)cmd批量创建目录及子目录 //创建各个目录,及charts和子目录bar md home category product role user charts\b ...

  5. 手动搭建I/O网络通信框架2:Socket和ServerSocket入门实战,实现单聊

    第一章:手动搭建I/O网络通信框架1:Socket和ServerSocket入门实战,实现单聊 在第一章中运用Socket和ServerSocket简单的实现了网络通信.这一章,利用BIO编程模型进行 ...

  6. [Alibaba-ARouter] 简单好用的Android页面路由框架

    开发一款App,总会遇到各种各样的需求和业务,这时候选择一个简单好用的轮子,就可以事半功倍 前言 Intent intent = new Intent(mContext, XxxActivity.cl ...

  7. net Core 入门实战

    Asp.net Core 入门实战   Asp.Net Core 是开源,跨平台,模块化,快速而简单的Web框架. Asp.net Core官网的一个源码合集,方便一次性Clone 目录 快速入门 安 ...

  8. Blazor 路由及导航开发指南

    翻译自 Waqas Anwar 2021年4月2日的文章 <A Developer's Guide To Blazor Routing and Navigation> [1] 检查传入的请 ...

  9. Spark入门实战系列--10.分布式内存文件系统Tachyon介绍及安装部署

    [注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .Tachyon介绍 1.1 Tachyon简介 随着实时计算的需求日益增多,分布式内存计算 ...

  10. 快速入门系列--WebAPI--03框架你值得拥有

    接下来进入的是俺在ASP.NET学习中最重要的WebAPI部分,在现在流行的互联网场景下,WebAPI可以和HTML5.单页应用程序SPA等技术和理念很好的结合在一起.所谓ASP.NET WebAPI ...

随机推荐

  1. 知乎问题:为什么很多web项目还是使用 px,而不是 rem?

    阅读过几篇关于 px rem 的文章,感觉 rem 很强大.但是自己接触到的公司项目全部都使用 px,想知道为什么.是我司技术更新落后了吗? 我们当然有在用 vw 和 vh,但是只是在 layout ...

  2. storybook 7.6

    https://storybook.js.org/tutorials/intro-to-storybook/vue/zh-CN/get-started/ 开始吧 注释:degit 从 github 拉 ...

  3. Windows自动更新hosts(bat脚本方式)

    为了解决无法打开 github 网页的问题,才有了这个自动更新hosts 的命令脚本 hosts 里的内容会每日更新,内容从这里拿 文件:https://raw.hellogithub.com/hos ...

  4. 在 macOS上安装 MongoDB 社区版

    官网教程 https://docs.mongodb.com/manual/tutorial/install-mongodb-on-os-x/ 使用第三方 brew package manager 在 ...

  5. 14. 迭代器、生成器、模块与包、json模块

    1.迭代器 1.1 迭代器介绍 迭代器是用来迭代取值的工具 每一次迭代得到的结果会作为下一次迭代的初始值,单纯的重复并不是迭代 # while循环实现迭代取值 a = [1, 2, 3, 4, 5, ...

  6. nginx服务器下laravel项目无法访问

    nginx服务器下laravel项目无法访问 后台用的nginx服务器,之前在本地开发项目时用的apache服务器,没想到切换到线上访问时除了首页一直显示404的错误,网页无法访问,网上搜索发现是ng ...

  7. 称骨算命免费api接口_json数据接口示例_八字称骨测算程序php接口

    称骨算命是算命方法的一种,和生辰八字算命.紫微斗数算命异曲同工,略有不同,虽然都是用出生的时间算命,但比较而言,称骨算命将命运分的比较粗略,只是把命运分为五十一种.故对命运的考察不细致,不太准确,可以 ...

  8. HN CSP-J 2023 奇人鉴赏

    其中有 4 位同学提到了IOI 一位同学提到了 fk,但是并没有 Fk CCF 共有52个 CCF,其中HN-J00157同学复制了很多遍题目一位同学用了ccf当 struct 名字,并且写出了人名函 ...

  9. KubeSphere 社区双周报|2024.03.15-03.29

    KubeSphere 社区双周报主要整理展示新增的贡献者名单和证书.新增的讲师证书以及两周内提交过 commit 的贡献者,并对近期重要的 PR 进行解析,同时还包含了线上/线下活动和布道推广等一系列 ...

  10. KubeSphere 社区双周报 | OpenFunction v1.0.0-rc.0 发布

    KubeSphere 社区双周报主要整理展示新增的贡献者名单和证书.新增的讲师证书以及两周内提交过 commit 的贡献者,并对近期重要的 PR 进行解析,同时还包含了线上/线下活动和布道推广等一系列 ...