微信小程序 ios 手机底部安全区适配

在开发微信小程序中,遇到 IOS 全面屏手机,底部小黑条会遮挡页面按钮或内容,因此需要做适配处理。

解决方案

通过 wx.getSystemInfo() 获取手机系统信息,需要拿到:screenHeight (屏幕高度),safeArea (安全区域对象),pixelRatio(像素比)。然后通过计算,得到底部安全区的高度,动态设置底部元素的高度。

js 复制代码
Page({
  data: {
    bottomHeight: 0,
  },
  onLoad() {
    this.safeAreaHandle()
  },
  async safeAreaHandle() {
    let {
      screenHeight,
      pixelRatio,
      safeArea: { bottom },
    } = await wx.getSystemInfo()
    this.setData({
      bottomHeight: (screenHeight - bottom) * pixelRatio,
    })
  },
})

screenHeight 是指屏幕高度,单位为 px
safeArea.bottom 是指安全区域右下角纵坐标,单位为 px
pixelRatio 设备像素比。

iPhone 6/7/8 为例,pixelRatio2 ,即:375px=750rpx

计算公式:底部安全区高度 = (屏幕高度 - 安全区域右下角纵坐标) * 像素比 ,由此计算可得到底部安全区的高度,单位是 rpx

动态设置底部安全区的高度:

html 复制代码
<template name="footer">
  <view class="page-footer" style="padding-bottom:{{bottomHeight + 20 +'rpx' }}">
    <view class="optional-li">
      <view wx:for="{{labels}}" wx:key="labelCode" bindtap="clickLabel" data-args="{{item}}" class="opt-item">
        {{item.labelName}}
      </view>
    </view>
  </view>
</template>

参考文档:https://developers.weixin.qq.com/miniprogram/dev/api/base/system/wx.getSystemInfo.html


欢迎访问:天问博客

相关推荐
橘猫云计算机设计4 小时前
ASP.NET图书馆借阅系统(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·后端·爬虫·小程序·毕业设计·asp.net
凡科网小帆6 小时前
VR体验馆如何用小程序高效引流?3步打造线上预约+团购裂变系统
小程序·vr·小程序制作
qq_424409196 小时前
微信小程序生成某个具体页面的二维码
微信小程序·小程序
编程迪6 小时前
找搭子系统 搭子经济新风口 基于精准匹配的社交新生态探索
小程序·交友·找搭子·组局系统·交友软件·活动报名
说私域8 小时前
定制开发开源AI智能名片S2B2C商城小程序源码中的产品运营协同进化机制研究
人工智能·小程序·开源·产品运营·零售
雯0609~9 小时前
微信小程序:动态表格实现,表头单元格数据完全从data中获取,宽度自定义,自定义文本框,行勾选,样式效果,横向滚动表格(解决背景色不足的问题)等
微信小程序·小程序·notepad++
前端笨鸟10 小时前
放弃云数据库!基于NestJS的WebSocket实时通信方案实践
websocket·微信小程序·nestjs
代码吐槽菌11 小时前
基于微信小程序的智慧乡村旅游服务平台【附源码】
java·开发语言·数据库·后端·微信小程序·小程序·毕业设计
依辰16 小时前
跨框架组件调用在小程序场景的实践分享
前端·javascript·微信小程序
散歌16 小时前
小程序 RecorderManager 录音分贝解析及来电检测
微信小程序·音视频开发