#鸿蒙通关秘籍#如何为Navigation配置动态路由以实现模块解耦?

HarmonyOS
2024-12-05 14:53:35
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
云海巅SCRM

HarmonyOS中的Navigation组件支持通过系统路由表配置动态路由,主要流程如下:

  1. 在HSP(HAR)中完成自定义组件并申明为export
@Component
export struct PageInHSP {
  build() {
    NavDestination() {
        ...
    }
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  1. 在HSP(HAR)的index.ets中导出组件。
export { PageInHSP } from "./src/main/ets/pages/PageInHSP"
  • 1.
  1. 在导入此HSP(HAR)组件的页面中,通过Navigation管理页面跳转:
import { PageInHSP } from 'library/src/main/ets/pages/PageInHSP'

@Entry
@Component
struct MainPage {
 pageStack: NavPathStack = new NavPathStack()

 @Builder pageMap(name: string) {
   if (name === 'PageInHSP') {
     PageInHSP()
   }
 }
 build() {
   Navigation(this.pageStack) {
     Button("Push HSP Page")
       .onClick(() => {
         this.pageStack.pushPath({ name: "PageInHSP" });
     })
   }
   .navDestination(this.pageMap)
 }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.

在这种流程下,不同模块之间无需直接依赖,大大增强了模块的解耦性。

分享
微博
QQ
微信
回复
2024-12-05 16:41:03
相关问题
HarmonyOS 模块方案如何实现
1177浏览 • 1回复 待解决
Navigation实现动态路由的方式
1546浏览 • 1回复 待解决