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

HarmonyOS
7天前
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
云海巅SCRM

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

  1. 在HSP(HAR)中完成自定义组件并申明为export
@Component
export struct PageInHSP {
  build() {
    NavDestination() {
        ...
    }
  }
}
  1. 在HSP(HAR)的index.ets中导出组件。
export { PageInHSP } from "./src/main/ets/pages/PageInHSP"
  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)
 }
}

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

分享
微博
QQ
微信
回复
7天前
相关问题
HarmonyOS 模块方案如何实现
239浏览 • 1回复 待解决
Navigation实现动态路由的方式
698浏览 • 1回复 待解决