小程序返回按钮,兼容所有机型的高度办法

现象

在使用返回按钮的时候在不同机型上返回按钮小图标位置总是不一样,一会高一会低。

原因

因为手机的状态栏一般是不一样的,导致设置固定高度的时候就随时在改变。

解决办法

  1. 直接获取胶囊按钮的top值和height值
  2. 将返回按钮的top值设置为一样的,将图标按钮高度设置一样的,注意宽度尽量大一点,防止图片失真。

实例代码

page.wxml

html 复制代码
<navigator open-type="navigateBack" class="back-button" 
           style="top: {{navTop}}px; height: {{navHeight}}px;" bindtap="goBack">
  <image src="https://serve.zimeinew.com/images/back.png" mode="aspectFit" />
</navigator>
属性 / 元素 作用说明
navigator 用于页面跳转组件。
open-type="navigateBack" 表示"返回上一页"。
class="back-button" 给返回按钮设置样式。
bindtap="goBack" 绑定点击事件 goBack 方法。
<image ... /> 返回按钮的图标。
mode="aspectFit" 控制图片显示的模式。aspectFit 表示:保持原始宽高比缩放图片。
css 复制代码
.back-button {
  position: fixed;
  left: 20rpx;
  top: 75rpx;
  width: 70rpx;
  height: 70rpx;
  z-index: 999;
}

.back-button image{
  width: 100%;
  height: 100%;
  /* object-fit: contain; 保证图片完整显示且不变形 */
}
javascript 复制代码
Component({
  properties: {},
  data: {
    navTop: 0,
    navHeight: 0
  },
  lifetimes: {
    attached() {
      this.getNavHeight();
    }
  },
  methods: {
    getNavHeight() {
      const menuButtonInfo = wx.getMenuButtonBoundingClientRect(); // 获取胶囊按钮信息
      const navTop = menuButtonInfo.top; // 胶囊按钮顶部坐标
      const navHeight = menuButtonInfo.height; // 胶囊按钮右侧坐标

      this.setData({
        navTop: navTop,
        navHeight: navHeight
      });
    }
  }
});

总结

返回按钮Top和Height与胶囊属性相同。

扩展

不同设备的状态栏属性

获取胶囊按钮信息

javascript 复制代码
const menuButtonInfo = wx.getMenuButtonBoundingClientRect(); // 获取胶囊按钮信息
console.log(menuButtonInfo)

获取设备信息,获取设备状态栏高度

javascript 复制代码
const systemInfo = wx.getSystemInfoSync(); // 获取系统信息
const statusBarHeight = systemInfo.statusBarHeight; // 状态栏高度
console.log(systemInfo)
console.log(statusBarHeight)
相关推荐
说私域14 小时前
短视频私域流量池的变现路径创新:基于AI智能名片链动2+1模式S2B2C商城小程序的实践研究
大数据·人工智能·小程序
毕设源码-邱学长16 小时前
【开题答辩全过程】以 基于微信小程序的松辽律所咨询系统的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
+VX:Fegn089518 小时前
计算机毕业设计|基于springboot + vue物流配送中心信息化管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·小程序·课程设计
说私域18 小时前
B站内容生态下的私域流量运营创新:基于AI智能名片链动2+1模式与S2B2C商城小程序的融合实践
人工智能·小程序·流量运营
计算机毕设指导618 小时前
基于微信小程序的钓鱼论坛系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
qq_124987075318 小时前
基于微信小程序的宠物交易平台的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计
kyh100338112020 小时前
第二个微信小游戏《汉字碰碰消》上线啦!
微信·微信小程序·微信小游戏·去水印微信小程序·养了个羊
计算机毕设指导621 小时前
基于微信小程序的精致护肤购物系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
myzshare1 天前
实战分享:我是如何用SSM框架开发出一个完整项目的
java·mysql·spring cloud·微信小程序
sheji34161 天前
【开题答辩全过程】以 基于微信小程序的在线学习系统为例,包含答辩的问题和答案
学习·微信小程序·小程序