css移动端设备的安全区内边距

Safe Area Insets 在 Android 设备上的支持

safe-area-insets 主要是为了处理 iOS 设备上的"刘海屏"和其他不可见区域而引入的,但现代的 Android 设备也存在类似的问题,例如屏幕凹槽、摄像头打孔、底部导航栏等。幸运的是,safe-area-insets 也可以在 Android 设备上使用,因为现代浏览器普遍支持 env() 函数。

支持情况

  • iOS 设备safe-area-insets 在 iOS 设备上得到了很好的支持,尤其是在 Safari 浏览器中。
  • Android 设备 :现代浏览器(如 Chrome、Firefox、Edge)在 Android 设备上也支持 safe-area-insets,尽管支持程度可能因设备和浏览器版本而异。

示例

iPhone X 及其后续型号的"刘海"和底部导航栏。通过使用 constant()env() 函数,可以确保内容不会被这些区域遮挡。

css 复制代码
/* 使用 constant() 函数 */
margin-bottom: max(constant(safe-area-inset-bottom), 20px);

/* 使用 env() 函数 */
margin-bottom: max(env(safe-area-inset-bottom), 20px);
/*。底部导航栏安全距离 */

详细解释

  • max(constant(safe-area-inset-bottom), 20px)

    • 作用 :取 constant(safe-area-inset-bottom)20px 中的较大值作为 margin-bottom
    • 说明 :如果设备底部的安全区内边距大于 20px,则使用安全区内边距;否则使用 20px
  • max(env(safe-area-inset-bottom), 20px)

    • 作用 :取 env(safe-area-inset-bottom)20px 中的较大值作为 margin-bottom
    • 说明 :如果设备底部的安全区内边距大于 20px,则使用安全区内边距;否则使用 20px

兼容性处理

为了确保在不同浏览器和不同版本的 iOS 上都能正确处理安全区内边距,通常会同时使用 constant()env() 函数。这样可以确保在所有支持的浏览器中都能获得正确的效果。

解释

  • constant(safe-area-inset-bottom):用于早期版本的 iOS(iOS 11 和 12),确保在这些版本的 Safari 上也能正确处理安全区内边距。
  • env(safe-area-inset-bottom):用于现代浏览器,包括最新版本的 Safari、Chrome、Firefox 和 Edge,确保在这些浏览器中也能正确处理安全区内边距。

除了底部,还提供了top left right 的安全距离

css 复制代码
padding-top: max(constant(safe-area-inset-top), 20px);
padding-top: max(env(safe-area-inset-top), 20px);
/ * 获取顶部刘海屏安全距离 * /
css 复制代码
padding-top: max(constant(safe-area-inset-left), 20px);
padding-top: max(env(safe-area-inset-left), 20px);
/ * 获取左侧安全距离 * /

padding-top: max(constant(safe-area-inset-right), 20px);
padding-top: max(env(safe-area-inset-right), 20px);
/ * 获取右侧安全距离 * /

CSS 提供了 safe-area-inset-leftsafe-area-inset-right 来获取设备左右的安全区内边距。这些属性用于确保内容不会被设备左右的不可见区域(如侧边按钮或边框)遮挡。

相关推荐
sorryhc15 分钟前
如何设计一个架构良好的前端请求库?
前端·javascript·架构
lvchaoq40 分钟前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js
郝开44 分钟前
6. React useState基础使用:useState修改状态的规则;useState修改对象状态的规则
前端·javascript·react.js
Codigger官方1 小时前
Linux 基金会牵头成立 React 基金会:前端开源生态迎来里程碑式变革
linux·前端·react.js
90后的晨仔1 小时前
🌟 Vue3 + Element Plus 表格开发实战:从数据映射到 UI 优化的五大技巧
前端
ObjectX前端实验室2 小时前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者2 小时前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱2 小时前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
路很长OoO2 小时前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos
开水好喝3 小时前
Code Coverage Part I
前端