鸿蒙NEXT开发-页面路由

72 阅读1分钟

路由

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

路由这块知识点包括:

1、创建页面

2、页面跳转和后退

3、页面栈

4、路由模式

5、跳转传参

新建页面

router的使用都是基于Entry修饰的组件

都是基于resources/base/profile/main-page.json中的路由配置来跳转的

@Entry
@Component
struct Detail {
  @State message: string = 'Hello World';

  build() {
    Column() {
      Text(this.message)
        .fontSize(50)
        .fontWeight(FontWeight.Bold)
    }
    .height('100%')
    .width('100%')
  }
}

页面的跳转和后退

其中pushUrl会在当前页面层级再加一层页面,不管是不是同一个页面,

A -> B 相当于当前页面栈中存在两个页面 A和B

鸿蒙系统最多页面栈为32

页面栈

页面栈是用来存储程序运行时页面的一种数据结构,遵循先进后出的原则

页面栈的最大容量是32个页面

压栈

router.pushUrl()

获取页面栈的长度

router.getLength()

清空页面栈

router.clear()

路由模式

路由提供了两种不同的跳转模式

1、Standard:无论之前是否添加过,一直添加到页面栈(默认)

2、Single:如果目标页面已存在,会将已有的最近同url页面移到栈顶(看情况使用)

Button('点我').onClick(() => {
  router.pushUrl({
    url: 'pages/Edit'
  },router.RouterMode.Standard)
})

路由传参

Button('点我').onClick(() => {
  router.pushUrl({
    url: 'pages/Edit',
    params:{
      name:'东林'
    }
  },router.RouterMode.Standard)
})
aboutToAppear(): void {
  console.log(JSON.stringify(router.getParams()))
}