小程序自定义导航栏 navigationStyle

本文介绍了微信小程序中如何自定义导航栏,包括关闭原生头部导航的设置、自定义组件的使用,以及在app.wxss中添加page属性和创建布局的步骤。通过这些规则,可以实现导航栏的个性化定制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

小程序自定义导航栏

  • 微信提供自定义导航栏说明
  • 开始自定义导航栏组件

微信提供自定义导航栏说明

  • 微信版本 6.60
  • window下的 navigationStyle 属性,设置为 custom 即可关闭原生头部导航,但会保留椭圆形菜单。
  • Tip 暂时不支持单页面设置 navigationStyle 属性

开始自定义导航栏

了解规则

iPhone X : 导航栏高度 44 、 状态栏高度 44 、tabBar高度 83
其他机型 : 导航栏高度 44 、 状态栏高度 20 、 tabBar高度 49

自定义组件
  • app.wxss 添加page属性

    page {
      position: absolute;
      top: 0;
      bottom: 0;
      height: 100%;
      background-color: #f8f8f8;
      font-size: 32rpx;
      color: #333;
      display: flex;
      flex-direction: column;
    }
    
  • 页面使用2层流式布局

    <view >
        <view class='navigation'></view>
        <view class='container'></view>
    </view>
    
  • container使用布局 flex:1这个一定要加上

    .container{
      flex: 1;
      display: flex;
      flex-direction: column;
      position: relative;
    }
    
  • navigation组件
    1.js

    setNavigation(){  
        let startBarHeight = 20
        let navgationHeight = 44
        let that = this
        wx.getSystemInfo({
          success: function (res) {
            console.log(res.model)
            if (res.model == 'iPhone X'){
              startBarHeight = 44
            }
            that.setData({
              startBarHeight: startBarHeight,
              navgationHeight: navgationHeight
            })
          }
        })
      },
    

2.wxml

    <view class='navigation'>
      <view class='startBar' style='height:{{startBarHeight}}px'></view>
      <view class='navgation' style='height:{{navgationHeight}}px'></view>
    </view>

最后封装成组件即可

写在最后

感觉这个玩意还是官方给的香,如果现在项目用起来就自己封装一个用吧。
期待出单页面设置navigationStyle

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值