微信小程序自定义导航栏定位及胶囊按钮图解

news/2024/10/16 2:22:15/

在自定义小程序导航栏时,右上角的胶囊(MenuButton)在不同机型测试,会发现很难适配。

实测中 不同的手机,胶囊高度不一样、状态栏高度不一样。与模拟器显示的情况是不一样的。
由于小程序在不同的手机上顶部布局会发生变化,不能正确避开胶囊位置,所以通过官方给出的胶囊信息,可以计算出胶囊位置,完全需要根据手机,动态的计算高度。

演示:

图解胶囊按钮位置:

这是在没有设置自定义时的原生导航栏,我们发现整体的高度就是 (状态栏高度 + 导航栏高度)
而状态栏高度可以通过 wx.getSystemInfo()获取,现在就只用解决导航栏高度了

观察发现,胶囊顶部高度距导航栏顶部高度的高度差 和 胶囊底部高度距导航栏底部高度的高度差,是一样的
也就是说 导航栏高度 = 胶囊高度 +(高度差)x  2
而胶囊信息可以通过 wx.getMenuButtonBoundingClientRect() 获取,现在就只用解决高度差了
wx.getMenuButtonBoundingClientRect() 中也返回了胶囊顶部距屏幕顶部距离的信息(top)
所以知 **高度差 = 胶囊顶部距屏幕顶部距离 - 状态栏高度**  

重要事情说三遍
计算出来的值一定要用px,不要用rpx!
计算出来的值一定要用px,不要用rpx!!
计算出来的值一定要用px,不要用rpx!!!

这样我们可以定义一些全局变量

app.js代码:

javascript hljs">App({onLaunch: function () {const systemInfo = wx.getSystemInfoSync(); //获取系统信息const menuInfo = wx.getMenuButtonBoundingClientRect(); // 获取胶囊按钮的信息this.globalData.menuHeight = menuInfo.height; // 获取胶囊按钮的高this.globalData.statusBarHeight = systemInfo.statusBarHeight; // 获取状态栏的高this.globalData.menuRight = menuInfo.right; // 获取胶囊按钮的距离屏幕最右边的距离(此处用于设置导航栏左侧距离屏幕的距离)this.globalData.navBarHeight = (menuInfo.top - systemInfo.statusBarHeight) * 2 + menuInfo.height; // 计算出导航栏的高度this.globalData.navBarBottom = this.globalData.navBarHeight + systemInfo.statusBarHeight;this.globalData.winHeight = systemInfo.windowHeight;this.autoUpdate();},globalData: {navBarHeight:0,// 导航栏高度navBarBottom: 0,//胶囊按钮底部位置menuHeight:0,//胶囊按钮 高度statusBarHeight:0,//状态栏高度menuRight:0,//胶囊按钮 距离屏幕右边的距离winHeight:0},
})
wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

http://www.ppmy.cn/news/1426404.html

相关文章

4.19作业 驱动开发

一、编程要求 在内[[核中不支持浮点类型打印将si7006硬件数据读取到内核空间,拷贝到用户空间在i2c子系统驱动中,需要编写读取温湿度传感器函数在probe函数中 注册字符设备驱动(分步注册)自动创建设备节点通过ioctl函数判断应用层发送命令码,…

(SpringBoot)第十二章第一节:Spring事务和@Transactioal

文章目录 一:回顾事务的基本概念(1)事务A:定义B:事务的定义(2)事务的四个特性——ACIDA:数据库的ACID①:原子性(Atomicity)②:一致性(Consistency)③:隔离性(Isolation)④:持续性(Durability)B:破坏ACID的因素二:Spring

IO——线程

1. 什么是线程 1.1概念 线程是一个轻量级的进程,为了提高系统的性能引入线程。 线程和进程都参与统一的调度。 在同一个进程中可以创建的多个线程, 共享进程资源。 (Linux里同样用task_struct来描述一个线程) 1.2进程和线程的区别 相同点…

JavaEE初阶Day 14:多线程(12)

目录 Day 14 :多线程(12)CAS的ABA问题Callable接口ReentrantLock信号量SemaphoreCountDownLatch集合类的多线程安全问题1. Collections.synchronizedList(new ArrayList)2. CopyOnWriteArrayList3. BlockingQueue4. ConcurrentHashMap Day 14…

Jenkins机器已经安装了ansible, 运行的时候却报错ansible: command not found

操作系统:MacOS Jenkins log提示 ansible: command not found 直接在Jenkins 机器中,进入一样的目录执行ansible --version OK 原因: Jenkins 默认使用的环境是 /usr/bin, 而我的ansible 安装配置在conda3 下面,所以需要在Jenkin…

【QT进阶】Qt Web混合编程之html、 js的简单交互

往期回顾 【QT进阶】Qt Web混合编程之VS2019 CEF的编译与使用(图文并茂超详细介绍)-CSDN博客【QT进阶】Qt Web混合编程之QWebEngineView基本用法-CSDN博客【QT进阶】Qt Web混合编程之CMake VS2019编译并使用QCefView(图文并茂超详细版本&…

网页SAP导出Excel报表提示“执行xls文件不存在”的解决方法

问题截图 解决办法一:降级谷歌浏览器版本在69-87之间,再次打开访问即可顺利导出网页sap报表。 解决方法二: 安装office或者wps软件,安装并配置相应sap客户端系统,如果在外网办公,还需要安装公司VPN客户端…

【快捷部署】020_Jenkins(2.60.3)

📣【快捷部署系列】020期信息 编号选型版本操作系统部署形式部署模式复检时间020Jenkins2.60.3Ubuntu 20.04Docker单机2024-04-17 一、快捷部署 #!/bin/bash ################################################################################# # 作者&#xff1…