鴻蒙極速入門(五)-路由管理(Router)

来源:https://www.cnblogs.com/anywherego/archive/2023/10/26/17790103.html
-Advertisement-
Play Games

頁面路由指在應用程式中實現不同頁面之間的跳轉和數據傳遞。HarmonyOS提供了Router模塊,通過不同的url地址,可以方便地進行頁面路由,輕鬆地訪問不同的頁面。 一、基礎使用 Router模塊提供了兩種跳轉模式,分別是router.pushUrl()和router.replaceUrl()。這 ...


頁面路由指在應用程式中實現不同頁面之間的跳轉和數據傳遞。HarmonyOS提供了Router模塊,通過不同的url地址,可以方便地進行頁面路由,輕鬆地訪問不同的頁面。

一、基礎使用

Router模塊提供了兩種跳轉模式,分別是router.pushUrl()和router.replaceUrl()。這兩種模式決定了目標頁面是否會替換當前頁。

  • router.pushUrl():目標頁面不會替換當前頁,而是壓入頁面棧。這樣可以保留當前頁的狀態,並且可以通過返回鍵或者調用router.back()方法返回到當前頁。
  • router.replaceUrl():目標頁面會替換當前頁,並銷毀當前頁。這樣可以釋放當前頁的資源,並且無法返回到當前頁。

註意:頁面棧的最大容量為32個頁面。如果超過這個限制,可以調用router.clear()方法清空歷史頁面棧,釋放記憶體空間。

Router模塊提供了兩種實例模式,分別是Standard和Single。這兩種模式決定了目標url是否會對應多個實例。

  • Standard:多實例模式,也是預設情況下的跳轉模式。目標頁面會被添加到頁面棧頂,無論棧中是否存在相同url的頁面。
  • Single:單實例模式。如果目標頁面的url已經存在於頁面棧中,則會將離棧頂最近的同url頁面移動到棧頂,該頁面成為新建頁。如果目標頁面的url在頁面棧中不存在同url頁面,則按照預設的多實例模式進行跳轉。

在使用頁面路由Router相關功能之前,需要在代碼中先導入Router模塊。

import router from '@ohos.router';

跳轉示例

1.普通跳轉

function onJumpClick(): void {
  router.pushUrl({
    url: 'pages/Detail' // 目標url
  });
}

2.帶跳轉模式和跳轉結果

比如從其他頁面,跳轉到登錄頁面(全局唯一)

function onJumpClick(): void {
  router.pushUrl({
    url: 'pages/Detail' // 目標url
  }, router.RouterMode.Single, (err) => {
    if (err) {
      console.error(`Invoke pushUrl failed, code is ${err.code}, message is ${err.message}`);
      return;
    }
    console.info('Invoke pushUrl succeeded.');
  });
}

3.替換原頁面

比如從啟動頁面跳轉到首頁,同時需要銷毀啟動頁

function onJumpClick(): void {
  router.replaceUrl({
    url: 'pages/Profile' // 目標url
  });
}

4.帶參數

在調用Router模塊的方法時,添加一個params屬性,並指定一個對象作為參數:

class DataModelInfo {
  age: number;
}

class DataModel {
  id: number;
  info: DataModelInfo;
}

function onJumpClick(): void {
  // 在Home頁面中
  let paramsInfo: DataModel = {
    id: 123,
    info: {
      age: 20
    }
  };

  router.pushUrl({
    url: 'pages/Detail', // 目標url
    params: paramsInfo // 添加params屬性,傳遞自定義參數
  }, (err) => {
    if (err) {
      console.error(`Invoke pushUrl failed, code is ${err.code}, message is ${err.message}`);
      return;
    }
    console.info('Invoke pushUrl succeeded.');
  })
}

在目標頁面中,可以通過調用Router模塊的getParams()方法來獲取傳遞過來的參數。

const params = router.getParams(); // 獲取傳遞過來的參數對象
const id = params['id']; // 獲取id屬性的值
const age = params['info'].age; // 獲取age屬性的值

頁面返回

1.返回上一頁

router.back();

2.返回到指定頁面

router.back({
  url: 'pages/Home' // 指定url
});

3.返回到指定頁面,並傳遞自定義參數信息。

router.back({
  url: 'pages/Home',
  params: {
    info: '來自Home頁'
  }
});

4.目標頁面中,在需要獲取參數的位置調用router.getParams()方法即可,例如在onPageShow()生命周期回調中:

onPageShow() {
  const params = router.getParams(); // 獲取傳遞過來的參數對象
  const info = params['info']; // 獲取info屬性的值
}

頁面返回的特別說明

當使用router.back()方法返回到指定頁面時,該頁面會被重新壓入棧頂,而原棧頂頁面(包括)到指定頁面(不包括)之間的所有頁面棧都將被銷毀。

如果使用router.back()方法返回到原來的頁面,原頁面不會被重覆創建,因此使用@State聲明的變數不會重覆聲明,也不會觸發頁面的aboutToAppear()生命周期回調。如果需要在原頁面中使用返回頁面傳遞的自定義參數,可以在需要的位置進行參數解析。例如,在onPageShow()生命周期回調中進行參數解析。

二、命名路由

為了支持組件化,HarmonyOS支持多HAP機制共用包機制

在開發中為了跳轉到共用包中的頁面,可以使用router.pushNamedRoute()來實現,也就是命名路由的方式。

示例

在想要跳轉到的共用包頁面里,給@Entry修飾的自定義組件命名:

// library/src/main/ets/pages/Index.ets
// library為新建共用包自定義的名字
@Entry({ routeName : 'myPage' })
@Component
struct MyComponent {
}

配置成功後需要在需要跳轉的頁面中引入命名路由的頁面:

// entry/src/main/ets/pages/Index.ets
import router from '@ohos.router';
import 'library/src/main/ets/pages/Index' // 引入共用包library中的命名路由頁面

@Entry
@Component
struct Index {
  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Text('Hello World')
        .fontSize(50)
        .fontWeight(FontWeight.Bold)
        .margin({ top: 20 })
        .backgroundColor('#ccc')
        .onClick(() => { // 點擊跳轉到其他共用包中的頁面
          try {
            router.pushNamedRoute({
              name: 'myPage',
              params: {
                data1: 'message',
                data2: {
                  data3: [123, 456, 789]
                }
              }
            })
          } catch (err) {
            console.error(`pushNamedRoute failed, code is ${err.code}, message is ${err.message}`);
          }
        })
    }
    .width('100%')
    .height('100%')
  }
}

其他

基於命名路由技術方案時,建議將路由URL統一放在一個文件中做管理。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MDI窗體的相關學習使用 1、設置MDI父窗體 在屬性中找到IsMdiContainer選項,設置為True 2、添加MDI子窗體,在項目中依次選擇添加->窗體,然後一直預設即可 添加後的項目目錄(Form1為父視窗,Form2、Form3為子視窗) 3、在Form1.cs中,創建對應MDI子視窗的 ...
  • 【學習課程】:【【小白入門 通俗易懂】2021韓順平 一周學會Linux】 https://www.bilibili.com/video/BV1Sv411r7vd/?p=14&share_source=copy_web&vd_source=2c07d62293f5003c919b2df9b2e054 ...
  • 電腦數據的表示 1. 數值數據的表示 1.1 各種進位數的表示 二進位 (Binary) :以 0b 或 0B 開頭,字元僅含0和1. 用下標2或者數字後面加B表示。如 $(1011)_2$ 或 $1011B$ 八進位 (Octal) :以 0o 或 0O 開頭,字元含0-7. 用下標8或者數字後 ...
  • 1. 圖論 1.1. 起源於萊昂哈德·歐拉在1736年發表的一篇關於“哥尼斯堡七橋問題”的論文 1.2. 要解決這個問題,該圖需要零個或兩個具有奇數連接的節點 1.3. 任何滿足這一條件的圖都被稱為歐拉圖 1.4. 如果路徑只訪問每條邊一次,則該圖具有歐拉路徑 1.5. 如果路徑起點和終點相同,則該 ...
  • 天下武功,無堅不摧,唯快不破!我的名字叫 Redis,全稱是 Remote Dictionary Server。 有人說,組 CP,除了要瞭解她外,還要給機會讓她瞭解你。 那麼,作為開發工程師的你,是否願意認真閱讀此心法抓住機會來瞭解我,運用到你的系統中提升性能。 我遵守 BSD 協議,由義大利人 ...
  • 一、背景 公元2023-10-12(周四)上午,組內的亞梅反饋,用戶生成標簽報死鎖異常 二、排查異常日誌 查到當時報錯的日誌 具體異常信息如下 server-provider-info-2023-10-12.0.log:2023-10-12 09:40:50.593 [TID:bf623bded18 ...
  • 在資料庫中,對象的創建者將成為該對象的所有者,具有對該對象進行查詢、修改和刪除等操作的許可權。同時,系統管理員也擁有與所有者相同的許可權。 ...
  • 本文介紹了視頻黑屏的可能原因和解決方案。主要原因包括用戶主動關閉視頻、網路問題和渲染問題。解決方案包括優化網路穩定性、確保視頻渲染視圖設置正確、提供清晰的提示、實時監測網路質量、使用詳細的日誌系統、開啟視頻預覽功能、使用視頻流回調、處理編解碼問題、處理許可權問題、自定義視頻渲染邏輯和使用實時反饋系統。... ...
一周排行
    -Advertisement-
    Play Games
  • 當使用Autofac處理一個介面有多個實現的情況時,通常會使用鍵(key)進行區分或者通過IIndex索引註入,也可以通過IEnumerable集合獲取所有實例,以下是一個具體的例子,演示如何在Autofac中註冊多個實現,並通過構造函數註入獲取指定實現。 首先,確保你已經安裝了Autofac Nu ...
  • 本篇將分享Prometheus+Grafana的監控平臺搭建,並監控之前文章所搭建的主機&服務,分享日常使用的一些使用經驗本篇將配置常用服務的監控與面板配置:包括 MySQL,MongoDB,CLickHouse,Redis,RabbitMQ,Linux,Windows,Nginx,站點訪問監控,已... ...
  • 使用Aspirate可以將Aspire程式部署到Kubernetes 集群 工具安裝 dotnet tool install -g aspirate --prerelease 註意:Aspirate 正在開發中,該軟體包將作為預覽版進行版本控制,--prelease 選項將獲得最新的預覽版。 容器註 ...
  • 前言 本文要說的這種開發模式,這種模式並不是只有blazor支持,js中有一樣的方案next.js nuxt.js;blazor還有很多其它內容,本文近關註漸進式開發模式。 是的,前後端是主流,不過以下情況也許前後端分離並不是最好的選擇: 小公司,人員不多,利潤不高,創業階段能省則省 個人開發者,接 ...
  • 在.NET中,Microsoft.Extensions.Logging是一個靈活的日誌庫,它允許你將日誌信息記錄到各種不同的目標,包括資料庫。在這個示例中,我將詳細介紹如何使用Microsoft.Extensions.Logging將日誌保存到MySQL資料庫。我們將使用Entity Framewo ...
  • chatgpt介面開發筆記3: 語音識別介面 1.文本轉語音 1、瞭解介面參數 介面地址: POST https://api.openai.com/v1/audio/speech 下麵是介面文檔描述內容: 參數: { "model": "tts-1", "input": "你好,我是饒坤,我是ter ...
  • 前面兩篇文章主要是介紹瞭如何解決高併發情況下資源爭奪的問題。但是現實的應用場景中除了要解決資源爭奪問題,高併發的情況還需要解決更多問題,比如快速處理業務數據等, 本篇文章簡要羅列一下與之相關的更多技術細節。 1、非同步編程:使用async和await關鍵字進行非同步編程,這可以避免阻塞線程,提高程式的響 ...
  • 大家好,我是棧長。 Nacos 2.3.0 前幾天正式發佈了,新增了不少實用性的新功能,真是史上最強版本。 Nacos 2.3.0 還真是一個比較重要的大版本,因為它涉及了太多重大更新,今天棧長給大家來解讀下。 Nacos 先掃個盲: Nacos 一個用於構建雲原生應用的動態服務發現、配置管理和服務 ...
  • IDEA的遠程開發功能,可以將本地的編譯、構建、調試、運行等工作都放在遠程伺服器上執行,而本地僅運行客戶端軟體進行常規的開發操作即可,舊版本IDEA目前不支持該功能.,本例使用的是IDEA2023.2.5版本 下麵介紹如何在IDEA中設置遠程連接伺服器開發環境並結合Cpolar內網穿透工具實現無公網 ...
  • 本文解釋為啥會有響應式編程,為什麼它在開發者中不太受歡迎,以及引入 Java 虛擬線程後它可能最終會消失。 命令式風格編程一直深受開發者喜愛,如 if-then-else、while 迴圈、函數和代碼塊等結構使代碼易理解、調試,異常易追蹤。然而,像所有好的東西一樣,通常也有問題。這種編程風格導致線程 ...