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>
相关推荐
忙碌的菠萝6 小时前
微信小程序页面分享
微信小程序·小程序
前端 贾公子11 小时前
小程序请求加载提示防闪烁机制详解
小程序
y东施效颦13 小时前
使用uni-app ios 打包流程
uni-app
文慧的科技江湖13 小时前
充电桩运维管理工具系统的**详细功能列表** - 慧知开源充电桩平台
运维·分布式·小程序·开源·充电桩平台·充电桩开源平台
三脚猫的喵15 小时前
微信小程序使用画布实现飘落泡泡功能
前端·javascript·微信小程序·小程序
小柔说科技15 小时前
预制菜餐厅“信任崩塌”?上门私厨的透明化蓝海正待技术开垦!
小程序·软件开发·上门做饭小程序·厨师到家
iOS阿玮16 小时前
Pingpong和连连的平替,让AppStore收款无需新增持有人。
uni-app·app·apple
陈大左19 小时前
uniapp的更新流程【安卓、IOS、热更新】
android·ios·uni-app
莫魂魂21 小时前
005微信小程序npm包_全局数据共享和分包
微信小程序·小程序·npm
番茄Salad1 天前
解决在微信小程序中view组件下的text和images设置了样式display: flex; align-items: center;对不齐
微信小程序·小程序