首页 > 其他分享 >HarmonyOS Next 入门实战 - 导航框架:HMRouter

HarmonyOS Next 入门实战 - 导航框架:HMRouter

时间:2024-12-03 18:15:51浏览次数:4  
标签:100% HMRouter Next HarmonyOS export navPathStack HMRouterMgr 页面

基础知识

目前官方推荐的最佳解决方案,是官方对于Navigation导航组件的封装,使用更简单便捷。如果熟悉Navigation的话,使用起来很快上手。

首先先集成HMRouter模块
使用命令行安装依赖:

ohpm install @hadss/hmrouter

或在模块的 oh-package.json5 文件中添加依赖

{
  "dependencies": {
    "@hadss/hmrouter": "^1.0.0-rc.6",
  }
}

插件配置
在项目级的 hvigor/hvigor-config.json5 中添加插件依赖

{
  "dependencies": {
    "@hadss/hmrouter-plugin": "^1.0.0-rc.7"
  },
}

在模块的 hvigorfile.ts 文件中应用插件

import { hapTasks } from '@ohos/hvigor-ohos-plugin';
import { hapPlugin } from '@hadss/hmrouter-plugin';  //导入插件

export default {
    system: hapTasks,
    plugins:[hapPlugin()]   //应用插件,
}

//还有harPlugin(),hspPlugin(),模块是什么类型,就用对应的方法

在项目的build-profile.json5中,配置useNormalizedOHMUrl属性为true

{
  "app": {
    "products": [
      {
        "name": "default",
        "signingConfig": "debug",
        "compatibleSdkVersion": "5.0.0(12)",
        "runtimeOS": "HarmonyOS",
        "buildOption": {
          "strictMode": {
            "useNormalizedOHMUrl": true
          }
        }
      }
    ],
  }
}

HMRouter的配置就完成了。

初始化HMRouter

在入口的 UIAbility 类中(通常名字为EntryAbility )的 onCreate() 方法中调用HMRouter初始化方法,

export default class EntryAbility extends UIAbility {
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
    //初始化HMRouterMgr  
    HMRouterMgr.init({
      context: this.context
    })
  }
}

定义首页

HMNavigation 用来包裹首页内容:
其中 homePageUrl 为加载时显示的页面地址,options中可以设置框架的属性(NavModifier)和首页的元素,设置内容基本与Navigation相同。

class NavModifier extends AttributeUpdater<NavigationAttribute> {
  initializeModifier(instance: NavigationAttribute): void {
    instance.mode(NavigationMode.Stack);
    instance.navBarWidth('100%');
    instance.titleMode(NavigationTitleMode.Mini)
    instance.hideBackButton(true)
    // instance.hideNavBar(true)
  }
}


@Entry
@Component
struct HMRouterPage {
  static readonly TAG = 'HMRouterPage'
  modifier: NavModifier = new NavModifier()

  aboutToAppear(): void {

    HMRouterMgr.registerPageBuilder({
      builder: wrapBuilder(PageOneBuilder),
      pageUrl: "pageOne",
    })
  }

  build() {
    Column() {
      HMNavigation({
        homePageUrl: '',
        navigationId: 'mainNavigation', options: {
          // standardAnimator: HMDefaultGlobalAnimator.STANDARD_ANIMATOR,
          // dialogAnimator: HMDefaultGlobalAnimator.DIALOG_ANIMATOR,
          modifier: this.modifier,
          title: { titleValue: "首页" },
          menus: [{
            value: "menu1",
            icon: "resources/base/media/menu1.png",
            action: () => {

            }
          }, {
            value: "menu2",
            icon: "resources/base/media/menu2.png",
            action: () => {

            }
          }]
        }
      }) {
        PageMain()
      }
    }.width('100%').height('100%')
  }
}

定义子页
使用@HMRouter定义子页面路由
使用HMRouterMgr的 push(),replace(),pop()等方法进行页面之间的导航
使用HMRouterMgr.getCurrentParam()获取当页面的参数

//PageA
@HMRouter({ pageUrl: 'pageA' })
@Component
export struct PageA {
   build() {
    Column() {
      Text("Page A")
      Button("Page B").onClick(() => {
        HMRouterMgr.push({ pageUrl: 'pageB', param: "param" })
      })
      Button("Back").onClick(() => {
        HMRouterMgr.pop({ param: "pageA backParam" })
      })
    }
  }
}

//PageB
@HMRouter({ pageUrl: 'pageB'})
@Component
export struct PageB {
  @State params: string | undefined = HMRouterMgr.getCurrentParam()?.toString()
 
  build() {
    Column(){
      Text("Page B")
      Text("params:" + this.params)
      Button("Page B").onClick(()=>{
        HMRouterMgr.pop({ param: "pageB backParam" })
      })
    }
  }
}

另一种方法HMRouterMgr.registerPageBuilder
使用HMRouterMgr.registerPageBuilder()动态注册子页面路由,子页面内容使用NavDestination组件包括,无缝将Navigation框架迁移到HMRouterMgr

//定义子页面builder
@Builder
export function PageOneBuilder() {
  PageOne()
}

@Component
export struct PageOne {
  @State params: string | undefined = HMRouterMgr.getCurrentParam()?.toString()

  build() {
    NavDestination() {
      Column() {
        Text("page1")
          .padding(10)
          .fontSize(20)
          .fontWeight(500)
      }
      .width('100%')
      .height('100%')
      .alignItems(HorizontalAlign.Center)
      .justifyContent(FlexAlign.Center)
    }
    .title("page1")
    .menus([{
      value: "menu1",
      icon: "resources/base/media/menu1.png",
      action: () => {

      }
    }, {
      value: "menu2",
      icon: "resources/base/media/menu2.png",
      action: () => {
      }
    }])
  }
}

//动态注册路由
HMRouterMgr.registerPageBuilder({
  builder: wrapBuilder(PageOneBuilder),
  pageUrl: "page1",
})

HMRouter还有拦截器,生命周期,转场动画,服务路由等功能,限于篇幅不在细说,可以查看官方文档:
HMRouter官方文档
下面我们就开始搭建练习项目的路由框架

项目实践

注意:原本项目实战中打算使用HMRouter组件,实际发现使用HMRouter时菜单icon无法动态更新,因此替换成Navigation组件。
我们的demo中涉及三个页面,首页,详情页,作者页。首页作为路由主页面,详情页及作者页作为路由子页面。因此我们只需要注册后2个页面路由即可。

首页

@Builder
function PageMap(name: string) {
  if (name == PageURls.PoetryDetailPage) {
    PoetryDetailPage()
  } else if (name == PageURls.AuthorPage) {
    AuthorPage()
  }
}


//首页
@Entry
@Component
struct Index {
  @Provide('navPathStack') navPathStack: NavPathStack = new NavPathStack()

  build() {
    Stack() {
      Navigation(this.navPathStack) {
        Column() {
          Button(PageURls.PoetryDetailPage)
            .onClick(() => {
              this.navPathStack.pushPath({ name: PageURls.PoetryDetailPage })
            })
        }
      }
      .navDestination(PageMap)
      .titleMode(NavigationTitleMode.Mini)
      .title("首页")
      .hideBackButton(true)
    }.width('100%').height('100%')
  }
}

详情页

//详情页
@Component
export struct PoetryDetailPage {
  @Consume('navPathStack') navPathStack: NavPathStack

  build() {
    NavDestination() {
      Text("详情页")
    }.title({
      main: this.poetry!!.title,
      sub: `[${this.poetry!!.dynasty}]${this.poetry!!.author}`
    }).menus([{
      value: "作者",
      icon: "resources/base/media/ic_person_24px.svg",
      action: () => {
        this.navPathStack.pushPath({ name: PageURls.AuthorPage })
      }
    }])
  }
}

作者页

//作者页
@Component
export struct AuthorPage {
    @Consume('navPathStack') navPathStack: NavPathStack

  build() {
    NavDestination() {
      Column() {
        Text("AuthorPage")
      }
      .alignItems(HorizontalAlign.Center)
      .justifyContent(FlexAlign.Center)
      .width('100%')
      .height('100%')
    }.title(this.name)
  }
}
//PageUrl
export class PageUrls{
  public static PoetryDetailPage = 'PoetryDetailPage'
  public static AuthorPage = 'AuthorPage'
}

到此我们基本的导航框架已经搭建完成,下一步我们来实现首页的列表展示。


本文的技术设计和实现都是基于作者工作中的经验总结,如有错误,请留言指正,谢谢。

标签:100%,HMRouter,Next,HarmonyOS,export,navPathStack,HMRouterMgr,页面
From: https://www.cnblogs.com/shuijinglingsos/p/18584637

相关文章

  • Random.Shared.Next 使用
    Random.Shared.Next是.NET6引入的一个新特性,它提供了一个线程安全的随机数生成器。这意味着你可以在多线程环境中使用它,而不需要担心线程安全问题,如种子被意外修改等。Random.Shared.Next的使用方式如下:intr1=Random.Shared.Next(); //在0到int上限中随机。intr2=......
  • 【HarmonyOS开发】华为商城应用页面实验示例解析(ArkTS实战解析)
    一.实验背景本次项目为华为云鸿蒙应用入门级开发者认证的实验项目,借此来巩固对ArkTS的学习。实验源地址开发者云实验_云实验KooLabs_在线实验_上云实践_云计算实验_AI实验_华为云官方实验平台-华为云 实验目标本实验一共需要完成以下三个部分的任务:本实验将模拟制作......
  • HarmonyOS Next 密钥管理深度解析
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)中密钥管理相关技术细节,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:密钥管理系统架构一......
  • 深入 HarmonyOS Next 安全机制之加密算法
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)中加密算法相关技术细节,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:加密算法原理剖析一......
  • HarmonyOS Next 加密解密基础与密钥管理
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)中的加密解密技术与密钥管理相关知识,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:加密解......
  • HarmonyOS Next 加密通信技术实战
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)中加密通信技术的应用,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:加密通信原理与协议一......
  • HarmonyOS Next 加密技术在数据存储中的应用
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)中加密技术在数据存储方面的应用,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:数据存储安......
  • HarmonyOS:异步并发 (Promise和async/await)
    一、并发概述并发是指在同一时间内,存在多个任务同时执行的情况。对于多核设备,这些任务可能同时在不同CPU上并行执行。对于单核设备,多个并发任务不会在同一时刻并行执行,但是CPU会在某个任务休眠或进行I/O操作等状态下切换任务,调度执行其他任务,提升CPU的资源利用率。为了......
  • Abp Vnext Vue Element UI实现
    AbpVnextVueElementUI实现版本开箱即用的中后台前端/设计解决方案链接AbpProVben5VueElementPlus预览点击查看效果文档地址点击查看文档国内文档地址点击查看文档实现功能用户管理角色管理审计日志后台任务集成事件多语言Free......
  • IPv6 首部 Pad Length 中的 Next Header 字段取值及特殊取值
    PadLength字段取值范围8bit,标识Padding部分长度,0表示无填充。IPv6首部中,Padding部分的长度是可变的,用于填充使整个IPv6首部长度为8字节的倍数。其他部分的长度包括版本号Version、流量类别TrafficClass、流标签FlowLabel、负载长度PayloadLength、下......