【HarmonyOS 4.0】@ohos.router 页面路由

2024-08-31 10:04

本文主要是介绍【HarmonyOS 4.0】@ohos.router 页面路由,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 注册页面,在src/main/resources/base/profile/main_pages.json文件新增配置。
{"src": ["pages/Index","pages/AnimateTo"]
}
  1. 导入 router 模块
import router from '@ohos.router'

1. router.pushUrl

  1. 跳转到应用内的指定页面
  2. 会将当前页面压入历史页面栈,因此使用该方法跳转到目标页面之后,还可以再返回。
  3. router.pushUrl(options: RouterOptions1): Promise
  4. router.pushUrl(options: RouterOptions, mode: RouterMode2): Promise

2. router.replaceUrl

  1. 用应用内的某个页面替换当前页面,并销毁被替换的页面。不支持设置页面转场动效,如需设置,推荐使用Navigation组件。
  2. 会直接销毁当前页面并释放资源,用目标页替换当前页,因此使用该方法跳转到目标页面之后,不能返回。
  3. router.replaceUrl(options: RouterOptions1): Promise
  4. router.replaceUrl(options: RouterOptions, mode: RouterMode2): Promise

3. router.back

  1. 返回上一页面或指定的页面。
  2. 若上一个页面如果是 router.replaceUrl() 跳转到当前页面的,则 router.back() 不能返回。
  3. 若指定的页面不在历史页面栈中,也就是用户并未浏览过指定页面,那么将无法回到指定页面。
  4. router.back(options?: RouterOptions1 ): void

4. router.getParams

  1. 获取发起跳转的页面往当前页传入的参数。
  2. router.getParams(): Object
onPageShow(): void { // 页面每次显示时触发。使用 aboutToAppear 页面没反应。let record = router.getParams() as Record<string, string>if (record) {this.id = record['id']}
}

5. router.clear

  1. 清空页面栈中的所有历史页面,仅保留当前页面作为栈顶页面。
  2. router.clear(): void

6. router.getLength

  1. 获取当前在页面栈内的页面数量。
  2. router.getLength(): string

7. router.getState

  1. 获取当前页面的状态信息。
  2. router.getState(): RouterState3

8. router.showAlertBeforeBackPage

  1. 开启页面返回询问对话框。
  2. router.showAlertBeforeBackPage(options: EnableAlertOptions4): void

9. router.hideAlertBeforeBackPage

  1. 禁用页面返回询问对话框。
  2. router.hideAlertBeforeBackPage(): void

  1. RouterOptions 路由跳转选项。
    { url: string, params?: object } ↩︎ ↩︎ ↩︎

  2. RouterMode 路由跳转模式。
    2.1 router.RouterMode.Standard:多实例模式,也是默认情况下的跳转模式。目标页面会被添加到页面栈顶,无论栈中是否存在相同url的页面。
    2.2 router.RouterMode.Single:单实例模式。如果目标页面的url已经存在于页面栈中,则该url页面移动到栈顶。如果目标页面的url在页面栈中不存在同url页面,则按照默认的多实例模式进行跳转。 ↩︎ ↩︎

  3. RouterState 页面状态信息。
    3.1 index: number:表示当前页面在页面栈中的索引。从栈底到栈顶,index从1开始递增。
    3.2 name: string:表示当前页面的名称,即对应文件名。
    3.3 path: string:表示当前页面的路径。 ↩︎

  4. EnableAlertOptions 页面返回询问对话框选项。
    { message: string } 询问对话框内容 ↩︎

这篇关于【HarmonyOS 4.0】@ohos.router 页面路由的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1123586

相关文章

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

Nginx路由匹配规则及优先级详解

《Nginx路由匹配规则及优先级详解》Nginx作为一个高性能的Web服务器和反向代理服务器,广泛用于负载均衡、请求转发等场景,在配置Nginx时,路由匹配规则是非常重要的概念,本文将详细介绍Ngin... 目录引言一、 Nginx的路由匹配规则概述二、 Nginx的路由匹配规则类型2.1 精确匹配(=)2

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock