微信小程序自定义头部

1.在对应界面的json文件,将navigationStyle属性设置为"custom"

复制代码
"navigationStyle":"custom"
  1. 状态栏的高度可以通过 wx.getSystemInfo() 获取。

胶囊按钮的信息可以通过 wx.getMenuButtonBoundingClientRect() 获取。

导航栏高度=状态栏高度+胶囊按钮的高度+(胶囊按钮距离顶部的距离-状态栏的高度)*2。

由于胶囊按钮是原生组件,为表现一致,其单位在各个系统都为 px,所以自定义导航栏高度的单位都必须是 px,才能完美适配。

wxml

html 复制代码
<view class="header-box">
        <view style="height:{{capsuleHeight}}px;top:{{capsuleTop}}px" class='back'>
            <van-icon name="arrow-left" color="#333" bindtap='navBack' size="50rpx" />
        </view>
        <view class="nav-title" style="height:{{capsuleHeight}}px;top:{{capsuleTop}}px">物联网数据</view>
        <image src="/static/images/news.png" mode="scaleToFill"></image>
</view>

wxss:

css 复制代码
.header-box{
  width: 100%;
  position:relative;
}
.header-box image {
  width: 100%;
}
.other-box{
  position: absolute;
  top: 370rpx;
}
.back{
  position: absolute;
  left: 40rpx;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nav-title{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-size: 32rpx;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
}

js

javascript 复制代码
onLoad(){
    wx.getSystemInfo({
        success: res => {
          this.setData({
            statusBarHeight:res.statusBarHeight // 获取状态栏的高度
          })
        }
      })
      // 获取胶囊信息
      this.data.capsule = wx.getMenuButtonBoundingClientRect()  // 获取胶囊按钮的信息
      this.setData({
        capsuleTop:this.data.capsule.top, //  胶囊距离屏幕顶部的距离
        capsuleHeight:this.data.capsule.height, // 胶囊高度
      })
      this.setData({
         // 导航栏高度=状态栏高度+胶囊按钮的高度+(胶囊按钮距离顶部的距离-状态栏的高度)*2
        navbarHeight:(this.data.capsule.top-this.data.statusBarHeight)*2+this.data.capsule.height+this.data.statusBarHeight // 导航栏高度
      })
}

该页面自定义头部,也支持分享好友,导致分享出去点左上角的返回没有反应

javascript 复制代码
// 自定义导航返回按钮
navBack(){  
    let pages = getCurrentPages(); //获取所有页面
        if (pages.length <= 1){
        // 返回首页
            wx.switchTab({
             url: '/pages/index/index',
            });
        } else {
        // 返回上一页
          wx.navigateBack({
            delta: 1,
          });
        }      
  }
相关推荐
stark张宇5 小时前
超越 Hello World:深入小程序 Hybrid 初衷、安全配置与上线全链路
nginx·微信小程序·php
菜鸟una7 小时前
【瀑布流大全】分析原理及实现方式(微信小程序和网页都适用)
前端·css·vue.js·微信小程序·小程序·typescript
2501_915106329 小时前
iOS 混淆与 IPA 加固全流程,多工具组合实现无源码混淆、源码防护与可审计流水线(iOS 混淆|IPA 加固|无源码加固|App 防反编译)
android·ios·小程序·https·uni-app·iphone·webview
游戏开发爱好者89 小时前
用多工具组合把 iOS 混淆做成可复用的工程能力(iOS混淆 IPA加固 无源码混淆 Ipa Guard)
android·ios·小程序·https·uni-app·iphone·webview
lypzcgf10 小时前
商城小程序数据库表结构文档
数据库·小程序·电商
2501_9159214311 小时前
掌握 iOS 26 App 性能监控,从监测到优化的多工具组合流程
android·macos·ios·小程序·uni-app·cocoa·iphone
知识分享小能手11 小时前
uni-app 入门学习教程,从入门到精通, uni-app常用API的详细语法知识点(上)(5)
前端·javascript·vue.js·学习·微信小程序·小程序·uni-app
Strawberry9611 小时前
chooseVideo传视频无法取到缩略图
微信小程序
一匹电信狗12 小时前
【C++】手搓AVL树
服务器·c++·算法·leetcode·小程序·stl·visual studio
2501_9160088912 小时前
手机 iOS 系统全解析,生态优势、开发机制与跨平台应用上架实践指南
android·ios·智能手机·小程序·uni-app·iphone·webview