Uniapp-小程序自定义导航栏

一、项目背景

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

Uniapp-小程序自定义导航栏_第1张图片

但是我们需要的是

Uniapp-小程序自定义导航栏_第2张图片

二、原因

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

可以直接使用navigationBarBackgroundColor完成

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

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

三、自定义导航栏的使用

Uniapp-小程序自定义导航栏_第3张图片

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

Uniapp-小程序自定义导航栏_第4张图片

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

Uniapp-小程序自定义导航栏_第5张图片

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

onLoad() {
    // 状态栏高度
    this.statusBarHeight = uni.getSystemInfoSync().statusBarHeight; 
    // 胶囊数据
    const { top, height } = wx.getMenuButtonBoundingClientRect();
    // 自定义导航栏高度 = 胶囊高度 + 胶囊的padding*2, 如果获取不到设置为38
    this.barHeight = height ? height + (top - this.statusBarHeight) * 2 : 38;
},
        
        
        
        
            自定义标题
        

你可能感兴趣的:(uniapp,vue,uni-app,小程序)