微信小程序自定义导航栏【超详细】

前言

开发过程中,总会遇到ui给出的风格迥异的导航栏。比如:导航栏背景颜色渐变、导航栏背景是图片,等等。如果只用微信提供的navigationBarBackgroundColor肯定无法满足这些需求,因为它只能设置16进制的颜色,所以我们需要自定义导航栏,从而满足这些需求。

知识点

wx.getMenuButtonBoundingClientRect()

自定义导航栏我们一定要认识到这个方法,它可以获取菜单按钮(右上角胶囊按钮)的布局位置信息,通过该方法提供的信息,我们就能完美兼容不同屏幕的导航栏。

这是getMenuButtonBoundingClientRect所获取到的数据,咋一看不好理解,所以我给出了下面这张图,以下图解就很清楚了

步骤

  1. page.json 局部设置中取消自带的导航栏
json 复制代码
"navigationStyle": "custom"
  1. onLoad() 生命函数中获取胶囊信息,并通过胶囊信息设置自定义导航栏样式
js 复制代码
onLoad() {
    const {
        width,
        height,
        top,
        bottom,
        left,
        right
    } = wx.getMenuButtonBoundingClientRect();
    
    this.setData({
        tapNavSty: `height: ${bottom}px`
    });
}
  1. 样式文件中,设置导航栏容器的基本样式
wxss 复制代码
.top-nav-box {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%;
    background: linear-gradient(to bottom right, blue, pink);
}
  1. 模板文件中,绑定动态获取的导航栏高度
wxml 复制代码
<view class="top-nav-box" :style="topNavSty">

</view>
  1. 这样就得到自定义的导航栏效果啦

总结

理解getMenuButtonBoundingClientRect获取的胶囊信息,并且取消自带的导航栏,最终设置自定义导航栏,设置导航栏容器的基本样式时不仅仅可以设背景色,还是设置背景图片,从而满足设计需求啦

相关推荐
唐璜Taro10 分钟前
Vue3 + TypeScript 后台管理系统完整方案
前端·javascript·typescript
dustcell.19 分钟前
haproxy七层代理
java·开发语言·前端
掘金酱31 分钟前
「寻找年味」 沸点活动|获奖名单公示🎊
前端·人工智能·后端
患得患失94941 分钟前
【前端】前端动画优化的核心
前端
Xin_z_42 分钟前
Vue3 + Sticky 锚点跳转被遮挡问题解决方案
前端·javascript·vue.js
REDcker1 小时前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
修炼前端秘籍的小帅1 小时前
Stitch——Google热门的免费AI UI设计工具
前端·人工智能·ui
精神状态良好1 小时前
实战:从零构建本地 Code Review 插件
前端·llm
荒诞英雄1 小时前
Vue3 Teleport我真是没招了
前端·vue.js
YAY_tyy1 小时前
2025 最新版 Node.js 下载安装及环境配置教程
前端·node.js·教程·工具配置