鸿蒙开发之导航栏tabs(类似Android tablayout)

发布于:2024-03-22 ⋅ 阅读:(122) ⋅ 点赞:(0)

        当页面信息较多时,为了让用户能够聚焦于当前显示的内容,需要对页面内容进行分类,提高页面空间利用率。Tabs组件可以在一个页面内快速实现视图内容的切换,一方面提升查找信息的效率,另一方面精简用户单次获取到的信息量。

基本布局

        Tabs组件的页面组成包含两个部分,分别是TabContent和TabBar。TabContent是内容页,TabBar是导航页签栏,页面结构如下图所示,根据不同的导航类型,布局会有区别,可以分为底部导航、顶部导航、侧边导航,其导航栏分别位于底部、顶部和侧边。

一、头部

  @Builder
  AppStore(){
    Tabs({ barPosition: BarPosition.Start}){
      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("全部")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("已安装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("未安装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("更新")
    }
  }

二、底部

  @Builder
  AppStore(){
    Tabs({ barPosition: BarPosition.End}){
      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("全部")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("已安装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("未安装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("更新")
    }
  }

三、侧边导航(多用于横屏)

 @Builder
  AppStore(){
    Tabs({ barPosition: BarPosition.Start}){
      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("全部")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("安装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("未装")

      TabContent() {
        Column() {

        }
        .width('100%')
        .height('100%')
      }
      .tabBar("更新")
    }.vertical(true)
  }

接下来主要介绍自定义 tabs

自定义Tabs中的TabContent

在tabContent 添加要自定义的布局,如下代码

            TabContent() {
              Column() {
                Text('我的').height('100%')
              }
              .width('100%')
              .height('100%')
              .backgroundColor('#007DFF')
            }
            .tabBar(this.TabBuilder('我的', 3, $r('app.media.ic_tab_setting_sel'), $r('app.media.ic_tab_setting')))
 @Builder
  TabBuilder(title: string, targetIndex: number, selectedImg: Resource, normalImg: Resource) {
    Column() {
      Image(this.currentIndex === targetIndex ? selectedImg : normalImg)
        .size({ width: 25, height: 25 })
      Text(title)
        .margin({top:2})
        .fontColor(this.currentIndex === targetIndex ? '#ff7900' : '#6B6B6B')
    }
    .width('100%')
    .margin({top:2,bottom:2})
    .onClick(event => {
      this.currentIndex = targetIndex;
      this.tabsController.changeIndex(targetIndex);
    })
    .justifyContent(FlexAlign.Center)
  }


网站公告

今日签到

点亮在社区的每一天
去签到