鸿蒙ArkTS中两种自定义TabBar导航栏的方法

很多场景下,官方的TabBar并不如意,所以只能自定义,实现炫酷多彩的视觉效果。

两种方法:

      1.第一种,自定义Builder样式。

      2.第二种,用自定义的tabbar通过stack布局覆盖掉原生的。

区别:

      更加灵活,可以调整导航栏间距、位置

具体的代码是啥呢  :
//第二种方法的实现:
Stack({ alignContent: Alignment.Top }) {
      Tabs({ barPosition: BarPosition.Start, 
                index: $$this.currentIndex, 
            controller: this.tabController }) {
        ForEach(this.List, (item: Tab) => {
          TabContent(){
            Text('')
          }.tabBar('Title')
        })
      }
      Row ({ space: 30 }) {
        ForEach(this.List, (item: Tab) => {
          //自定义builder
            this.styleBar(item)
        })
      }
      .width('100%')
      .height(50)
   
    }

在uniapp实现自定义tabbar导航栏方法有多种。根据引用内容,可以看到有两种方法可以实现。 第一种方法是在父组件引入tabbar组件,并在onLoad生命周期函数隐藏原有的tabbar。然后在模板使用tabbar组件,并通过routePath属性指定每个tab对应的页面路径。通过这种方式,可以实现自定义的底部导航栏。\[1\] 第二种方法是创建一个总页面Index,并在模板引入自定义tabbar组件。然后在总页面Index引入自己写好的4个主页面(Home、Work、Message、My),并通过条件渲染的方式控制页面的切换。通过这种方式,可以实现自定义的底部导航栏。\[2\]\[3\] 以上是两种常见的实现自定义tabbar导航栏方法,你可以根据自己的需求选择其一种来实现。 #### 引用[.reference_title] - *1* [uniApp自定义tabBar导航](https://blog.csdn.net/qq_1307495/article/details/129584773)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [uni-app如何自定义实现tabbar导航栏](https://blog.csdn.net/weixin_70811193/article/details/127946635)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

现在也很好

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值