Uniapp-小程序自定义导航栏

一、项目背景

制作小程序页面时候发现原生导航栏有一定的高度是没有背景渲染的会出现这种情况

但是我们需要的是

二、原因

小程序的原生导航栏存在。一般可以使用 纯色填充顶部栏

可以直接使用navigationBarBackgroundColor完成

在style中添加 "navigationBarBackgroundColor": "#FED000"

但是业务需求需要添加自定义的效果,例如一整张背景图纯色填充

三、自定义导航栏的使用

黄色部分为状态栏高度 uni.getSystemInfoSync().statusBarHeight;

红色部分为自定义导航栏高度。wx.getMenuButtonBoundingClientRect

在页面onload时候就可以计算出相关高度了

javascript 复制代码
onLoad() {
    // 状态栏高度
    this.statusBarHeight = uni.getSystemInfoSync().statusBarHeight; 
    // 胶囊数据
    const { top, height } = wx.getMenuButtonBoundingClientRect();
    // 自定义导航栏高度 = 胶囊高度 + 胶囊的padding*2, 如果获取不到设置为38
    this.barHeight = height ? height + (top - this.statusBarHeight) * 2 : 38;
},
html 复制代码
        <!-- 状态栏高度 -->
        <view :style="{ height: `${statusBarHeight}px` }"></view>
        <!-- 自定义导航栏高度 并 居中 -->
        <view :style="{
          height: `${barHeight}px`,
          'line-height': `${barHeight}px`,
          'text-align': 'center',
        }">
            <text>自定义标题</text>
        </view>
相关推荐
融云5 分钟前
融云 uni-app IMKit 上线,1 天集成,多端畅行
uni-app
菜鸟una38 分钟前
【微信小程序 + 高德地图API 】键入关键字搜索地址,获取经纬度等
前端·vue.js·微信小程序·小程序·typescript
hopetomorrow5 小时前
学习路之uniapp --- 视频直播开发(在现有nginx服务器上搭建RTMP媒流体服务器)
学习·nginx·uni-app
番茄Salad5 小时前
微信小程序中,解决lottie动画在真机不显示的问题
微信小程序·小程序
繁依Fanyi6 小时前
用 UniApp 开发 TilePuzzle:一个由 CodeBuddy 主动驱动的拼图小游戏
前端·uni-app·编辑器·codebuddy首席试玩官
繁依Fanyi6 小时前
用 CodeBuddy 搭建「MiniGoal 小目标打卡器」:一次流畅的 UniApp 开发体验
前端·游戏·uni-app·codebuddy首席试玩官
hopetomorrow6 小时前
学习路之uniapp--unipush2.0推送功能--给自己发通知
uni-app
五秒法则6 小时前
uni-app使用大集
uni-app
七七小报6 小时前
uniapp-商城-59-后台 新增商品(属性的选中,进行过滤展示,filter,some,every和map)
uni-app
wx_cxc28486989186 小时前
羽毛球订场小程序源码介绍
微信小程序·小程序