#鸿蒙通关秘籍#如何在HarmonyOS NEXT中实现带有三个主要内容页的TabBar?

HarmonyOS
2024-11-28 15:55:06
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
hm673ff1119fd7d

在HarmonyOS NEXT中实现带有首页、知乎日报和我的页面三个主要内容页的TabBar,首先需要确保正确导入每个页面组件:

import Home from "../pages/home/Home"
import ZhiHu from "../pages/zhihu/Zhihu"
import Mine from "../pages/mine/Mine"

然后,创建一个名为Index的组件,使用Tabs组件来定义TabBar,这包括页面显示的生命周期管理、自定义Tab项样式、以及Tab内容的配置:

@Entry
@Component
struct Index {
  @State currentIndex: number = 0
  private controller: TabsController = new TabsController()

  onPageShow() {
    console.info('Index onPageShow');
  }

  onPageHide() {
    console.info('Index onPageHide');
  }

  onBackPress() {
    console.info('Index onBackPress');
  }

  build() {
    Column() {
      Tabs({
        barPosition: BarPosition.End,
        controller: this.controller
      }) {
        TabContent() {
          Home()
        }.tabBar(this.TabBuilder('首页', 0, $r('app.media.icon_sort'), $r('app.media.icon_sort_default')))

        TabContent() {
          ZhiHu()
        }.tabBar(this.TabBuilder('日报', 1, $r('app.media.search_select'), $r('app.media.search_default')))

        TabContent() {
           Mine()
        }.tabBar(this.TabBuilder('我的', 2, $r('app.media.user_selected'), $r('app.media.user')))
      }.scrollable(false)
    }
    .width('100%')
    .height('100%')
  }

  @Builder TabBuilder(title: string, targetIndex: number, selectedImg: Resource, normalImg: Resource) {
    Column() {
      Image(this.currentIndex === targetIndex ? selectedImg : normalImg)
        .size({ width: 25, height: 25 })
      Text(title)
        .fontColor(this.currentIndex === targetIndex ? '#28bff1' : '#8a8a8a')
    }
    .width('100%')
    .height(50)
    .justifyContent(FlexAlign.Center)
    .onClick(() => {
      this.currentIndex = targetIndex
      this.controller.changeIndex(this.currentIndex)
    })
  }
}
分享
微博
QQ
微信
回复
2024-11-28 15:35:13
相关问题
三个设备如何同时实现多端协同?
5402浏览 • 1回复 待解决