适配 IOS 安全区域

安全区域指的是一个可视窗口范围,处于安全区域的内容不受圆角(corners)、齐刘海(sensor housing)、小黑条(Home Indicator)影响。

造成这个问题的主要原因就是 iphoneX 之后在屏幕上出现了所谓的刘海屏,而且在屏幕下方加了一条小黑条。

在开发时,需要对顶部和底部预留一点空间,防止页面的内容被这些元素遮挡。在 iOS11 新增的特性中,Webkit 包含了两个新的函数和四个预定义的常量用来适配 IOS 的安全区域。

  1. constant():在 IOS11.2 系统之前使用。 constant()IOS11.2 系统之后被废弃了。

  2. env() :在 IOS11.2 系统之后使用。

  3. safe-area-inset-top:安全区域距离顶部边界距离,状态栏+导航栏大约为88px。

  4. safe-area-inset-left:安全区域距离左边边界距离,竖屏时为0。

  5. safe-area-inset-right:安全区域距离右边边界距离,竖屏时为0。

  6. safe-area-inset-bottom:安全区域距离底部边界距离,大约高度为34px。

    body{
    /* 兼容 iOS < 11.2 /
    padding-top: constant(safe-area-inset-top);
    padding-left: constant(safe-area-inset-left);
    padding-right: constant(safe-area-inset-right);
    padding-bottom: constant(safe-area-inset-bottom);
    /
    兼容 iOS >= 11.2 */
    padding-top: env(safe-area-inset-top);
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
    padding-bottom: env(safe-area-inset-bottom);
    }

相关推荐
黄油奥特曼14 天前
Flutter showModalBottomSheet用法
flutter·移动端
jcLee9525 天前
Flutter笔记:关于WebView插件的用法(上)
flutter·webview·dart·移动端
EmulateStep1 个月前
Day13:vw 和 vh 基本使用
css·css3·html5·web·移动端
starry陆离2 个月前
『跨端框架』Flutter环境搭建
android·flutter·前端框架·移动端
tangfuling19913 个月前
AugmentedReality之路-显示隐藏AR坐标原点(3)
ar·ue4·移动端
tangfuling19913 个月前
AugmentedReality之路-通过蓝图启动AR相机(2)
ar·ue4·移动端
萤火虫的小尾巴3 个月前
Android 开发环境搭建(Android Studio 安装图文详细教程)
android·java·ide·android studio·移动端
淡酒交魂4 个月前
「HarmonyOS」下拉刷新组件使用详情
华为·harmonyos·arkts·移动端