news 2026/6/22 16:07:23

HarmonyOS应用开发——页面路由

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HarmonyOS应用开发——页面路由

页面路由指在应用程序中实现不同页面之间的跳转和数据传递。

HarmonyOS提供了Router模块,通过不同的url地址,可以方便地进行页面路由,轻松地访问不同的页面。

包的使用及引用

import router from '@ohos.router'

1.pushUrl-压栈跳转

pushUrl(options: RouterOptions): Promise<void>

场景: 如果我们从列表页跳转到详情页查看详情,点击返回还要继续查看列表页,可以使用pushUrl,打开详情页的同时,保留了列表页在栈中。

接下来测试一下:

(1)建立两个Page,HmList和HmDetail,如图所示。

(2)实现HmList的布局,代码如下。

classListItemInfo{

title:string=""

id:number=0

}

@Entry

@Component

structHmList{

@Statelist:ListItemInfo[]=Array.from(Array(100),(_:number,index:number)=>{

return{

title:`我是第${index + 1}个`,

id:index+1

}asListItemInfo

})

build(){

Column({space:20}){

Row(){

Text("列表数据")

.textAlign(TextAlign.Center)

.width('100%')

.height(40)

}.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

List({space:10}){

ForEach(this.list,(item:ListItemInfo)=>{

ListItem(){

Row(){

Text(item.title)

Button("查看详情")

.height(30)

}.width('100%')

.justifyContent(FlexAlign.SpaceBetween)

.padding({

left:10,

right:10

})

}

})

}

}

}

}

实现效果,如图所示。

(3)实现HmDetail布局,代码如下:

@Entry

@Component

structHmDetail{

build(){

Column(){

Row(){

Text("详情页")

.width('100%')

.textAlign(TextAlign.Center)

}.height(40)

.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

Column(){

Text("详情页")

.fontSize(50)

}

.layoutWeight(1)

.justifyContent(FlexAlign.Center)

}

.height('100%')

}

}

实现效果,如图所示。

(4)在HmList中导入router包,完成路由跳转

importrouterfrom'@ohos.router'

Button("查看详情").onClick(() => {

router.pushUrl({ url: 'pages/HmDetail' })

})

完整代码如下:

importrouterfrom'@ohos.router'

classListItemInfo{

title:string=""

id:number=0

}

@Entry

@Component

structHmList{

@Statelist:ListItemInfo[]=Array.from(Array(100),(_:number,index:number)=>{

return{

title:`我是第${index + 1}个`,

id:index+1

}asListItemInfo

})

build(){

Column({space:20}){

Row(){

Text("列表数据")

.textAlign(TextAlign.Center)

.width('100%')

.height(40)

}.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

List({space:10}){

ForEach(this.list,(item:ListItemInfo)=>{

ListItem(){

Row(){

Text(item.title)

Button("查看详情").onClick(()=>{

router.pushUrl({url:'pages/HmDetail'})

})

.height(30)

}.width('100%')

.justifyContent(FlexAlign.SpaceBetween)

.padding({

left:10,

right:10

})

}

})

}

}

}

}

2.replaceUrl-替换跳转

有一个登录页(Login)和一个个人中心页(Profile),希望从登录页成功登录后,跳转到个人中心页。同时,销毁登录页,在返回时直接退出应用。

此时直接replaceUrl方法会在跳转的同时,销毁登录页,在上面的例子中,直接将pushUrl换成replaceUrl即可。

import router from '@ohos.router';

Button("查看详情").onClick(() => {

router.replaceUrl({ url: 'pages/HmDetail' })

})

})

总结

(1)当你需要跳转之后,还可以回到上一个页面,使用pushUrl,它会保留当前的页面,压一个新的页面

(2)当你跳转之后,上一个页面的任务已经完成,不需要返回,就可以使用replaceUrl

3.back返回

router.back() . 返回上一个页面,此时不需要参数,如果说你想要返回的时候带一些参数,需要params和url- 想要指定url.

(1)router.back()

在详情页加一个返回按钮,点击按钮调用router.back()。

importrouterfrom'@ohos.router'

Button("返回列表页")

.onClick(() => {

router.back()

})

添加一个返回按钮,完整代码如下:

importrouterfrom'@ohos.router'

@Entry

@Component

structHmDetail{

build(){

Column(){

Row(){

Text("详情页")

.width('100%')

.textAlign(TextAlign.Center)

}.height(40)

.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

Column(){

Text("详情页")

.fontSize(50)

Button("返回列表页")

.onClick(()=>{

router.back()

})

}

.layoutWeight(1)

.justifyContent(FlexAlign.Center)

}

.height('100%')

}

}

实现效果,如图所示。

4.路由参数

如果需要在跳转时,传递一些数据给目标页,比如列表页到详情页,想把id传过去,就可以使用路由传参的模式。

(1)修改HmList.ets文件,代码如下:

Button("查看详情").onClick(()=>{

router.pushUrl({

url:'pages/HmDetail',

params:{

id:item.id

}

})

})

(2)修改HmDetail.ets文件,子组件接收参数,代码如下:

importrouterfrom'@ohos.router'

classRouterParams{

id:number=0

}

@Entry

@Component

structHmDetail{

@State

detailId:number=0

aboutToAppear(){

constparams=router.getParams()asRouterParams

if(params?.id){

this.detailId=params?.id

}

}

build(){

Column(){

Row(){

Text("详情页")

.width('100%')

.textAlign(TextAlign.Center)

}.height(40)

.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

Column(){

Text("详情页"+this.detailId)

.fontSize(50)

Button("返回列表页")

.onClick(()=>{

router.back()

})

}

.layoutWeight(1)

.justifyContent(FlexAlign.Center)

}

.height('100%')

}

}

实现效果,如图所示。

router.back() 同样可以传递参数给上一级的路由,上一级路由应该在onPageShow里面接收详情页面返回传参。

(1)HmDetail.ets文件,详情组件添加“返回列表页带参数”按钮,代码如下:

Button("返回列表页带参数")

.onClick(() => {

router.back({

url: 'pages/HmList',

params: {

backId: this.detailId

}

})

})

(2)父组件接受参数,HmList.ets文件,代码如下:

class BackRouterParams {

backId: number = 0

}

onPageShow() {

const params = router.getParams() as BackRouterParams

if(params?.backId) {

AlertDialog.show({

message: params.backId.toString()

})

}

}

完整代码如下:

importrouterfrom'@ohos.router'

classListItemInfo{

title:string=""

id:number=0

}

classBackRouterParams{

backId:number=0

}

@Entry

@Component

structHmList{

@Statelist:ListItemInfo[]=Array.from(Array(100),(_:number,index:number)=>{

return{

title:`我是第${index + 1}个`,

id:index+1

}asListItemInfo

})

onPageShow(){

constparams=router.getParams()asBackRouterParams

if(params?.backId){

AlertDialog.show({

message:params.backId.toString()

})

}

}

build(){

Column({space:20}){

Row(){

Text("列表数据")

.textAlign(TextAlign.Center)

.width('100%')

.height(40)

}.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

List({space:10}){

ForEach(this.list,(item:ListItemInfo)=>{

ListItem(){

Row(){

Text(item.title)

Button("查看详情").onClick(()=>{

// router.pushUrl({ url: 'pages/HmDetail' })

// router.replaceUrl({ url: 'pages/HmDetail' })

router.pushUrl({

url:'pages/HmDetail',

params:{

id:item.id

}

})

})

.height(30)

}.width('100%')

.justifyContent(FlexAlign.SpaceBetween)

.padding({

left:10,

right:10

})

}

})

}

}

}

}

实现效果,如图所示。

->

总结:

(1)传参用params对象,里面可以传任意内容,key/value由开发者自己定义。

(2)接收端采用router.getParams()获取对象,需要通过class来定义参数的结构,接收之后通过类型断言as指定为具体类型。

(3)如果是通过pushUrl的方式跳转的,返回上一个页面时,aboutToAppear不会执行,需要使用onPageShow来监听当前页面的显示钩子函数。

5.路由模式

Standard:标准实例模式,也是默认情况下的实例模式。每次调用该方法都会新建一个目标页,并压入栈顶。

Single:单实例模式。即如果目标页的url在页面栈中已经存在同url页面,则离栈顶最近的同url页面会被移动到栈顶,并重新加载;如果目标页的url在页面栈中不存在同url页面,则按照标准模式跳转。

简单理解一下就是:

(1)Standard-只要push,页面栈里面就会加一项,不管之前加没加过。

(2)Single- 之前加过,不会加新的页面,会把之前加过的页面加出来。

测试- 在detail页面再push到list页,分别使用单例模式和标准模式测试。

Button("标准模式")

.onClick(() => {

router.pushUrl({

url: 'pages/HmList'

})

})

Button("单例模式")

.onClick(() => {

router.pushUrl({

url: 'pages/HmList'

}, router.RouterMode.Single)

})

这里会发现 使用single模式路由返回时的list已经不存在了,因为单例模式只要存在不会再压栈。

HmDetail.ets文件,完整代码如下:

importrouterfrom'@ohos.router'

classRouterParams{

id:number=0

}

@Entry

@Component

structHmDetail{

@State

detailId:number=0

aboutToAppear(){

constparams=router.getParams()asRouterParams

if(params?.id){

this.detailId=params?.id

}

}

build(){

Column(){

Row(){

Text("详情页")

.width('100%')

.textAlign(TextAlign.Center)

}.height(40)

.border({

color:'#f3f4f5',

width:{

bottom:1

}

})

Column(){

Text("详情页"+this.detailId)

.fontSize(50)

Button("返回列表页")

.onClick(()=>{

router.back()

})

Button("返回列表页带参数")

.onClick(()=>{

router.back({

url:'pages/HmList',

params:{

backId:this.detailId

}

})

})

Button("标准模式")

.onClick(()=>{

router.pushUrl({

url:'pages/HmList'

})

})

Button("单例模式")

.onClick(()=>{

router.pushUrl({

url:'pages/HmList'

},router.RouterMode.Single)

})

}

.layoutWeight(1)

.justifyContent(FlexAlign.Center)

}

.height('100%')

}

}

实现效果,如图所示。

欢迎加入课程班级,考取鸿蒙认证:

https://developer.huawei.com/consumer/cn/training/classDetail/d43582bb30b34f548c16c127cb3be104?type=1?ha_source=hmosclass&ha_sourceId=89000248

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 19:54:59

最小二乘问题详解4:非线性最小二乘

1. 引言在论述最小二乘问题的时候&#xff0c;很多文章都喜欢用拟合直线来举例&#xff0c;但是在现实中像拟合直线这样的线性最小二乘问题往往不是常态&#xff0c;现实世界中更多是像投影成像这种非线性最小二乘问题。在本文中&#xff0c;我们就讲解一下非线性最小二乘问题。…

作者头像 李华
网站建设 2026/6/22 23:51:53

不是所有旅行都要有意义,舒服才是答案

不晓得从什么时候开始&#xff0c;深度游成了旅游领域的热门词语&#xff0c;大家都不想匆匆地游览&#xff0c;就希望好好感受城市的“真实灵魂。认真思索一番&#xff0c;所谓深度或许算是一个虚假概念我们带着自身的学识&#xff0c;、成见还有期待出发&#xff0c;所看到的…

作者头像 李华
网站建设 2026/6/16 23:19:22

基于SpringBoot+Vue的大学生就业服务平台的设计与实现

一、前言 大学生就业服务平台管理系统按照操作主体分为管理员和用户。管理员的功能包括学生档案管理、字典管理、试卷管理、试卷选题管理、试题表管理、考试记录表管理、答题详情表管理、错题表管理、法律法规管理、法律法规收藏管理、法律法规留言管理、就业分析管理、论坛管理…

作者头像 李华
网站建设 2026/6/21 10:41:55

从零开始掌握LibreCAD:免费开源CAD软件的完全使用指南

从零开始掌握LibreCAD&#xff1a;免费开源CAD软件的完全使用指南 【免费下载链接】LibreCAD LibreCAD is a cross-platform 2D CAD program written in C14 using the Qt framework. It can read DXF and DWG files and can write DXF, PDF and SVG files. The user interface…

作者头像 李华
网站建设 2026/6/20 1:00:02

终极指南:免费在Mac上读写NTFS磁盘的简单方法

终极指南&#xff1a;免费在Mac上读写NTFS磁盘的简单方法 【免费下载链接】ntfstool A ntfs tool for mac 项目地址: https://gitcode.com/gh_mirrors/nt/ntfstool 还在为Mac电脑无法写入NTFS格式的移动硬盘而头疼吗&#xff1f;NTFSTool这款开源工具正是为你量身定制的…

作者头像 李华