一、media query方式
/*iPhone X 适配*/ @media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) { .fixed-bottom{ bottom: 37px; } } /*iPhone XS max 适配*/ @media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio:3) { .fixed-bottom{ bottom: 37px; } } /*iPhone XR max 适配*/ @media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio:2) { .fixed-bottom{ bottom: 37px; } }
存在的问题:在微信webveiw内部此方案能在元素底部加上安全区域宽度,没有问题。但是在safari等有底栏的浏览器(页面显示区域已经在安全区内部)也同样会加上安全区宽度。
二、CSS函数
苹果在推出全面屏之后提供的CSS函数,ios<11.2为constant(),ios>11.2为env()。可填入safe-area-inset-top、safe-area-inset-left、safe-area-inset-right、safe-area-inset-bottom对应上下左右的安全区域宽度。env 和 constant 只有在 viewport-fit=cover 时候才能生效。
代码如下:
meta标签加入viewport-fit=cover
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, viewport-fit=cover">
css写法,不支持env、constant的浏览器会忽略此样式
.fixed-bottom{ bottom: 0; bottom: constant(safe-area-inset-bottom); bottom: env(safe-area-inset-bottom); }
此方案能解决方案一的问题,且代码更简洁
到此这篇关于CSS适配iPhone全面屏的方法的文章就介绍到这了,更多相关CSS适配iPhone全面屏内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
flex-grow、flex-shrink、flex-basis三个属性的作用: 在flex布局中,父元素在不...
技术迷 html 网页,你指定知道 vue 尤尤开发的前端框架 element 外卖团队的前端u...
效果如下: 分析 1.这里看到的大概有三个圈 围着点在做放大动画 所以我们写四个...
我大概列出了一些价值,抛砖引玉一下,希望能够完善这个想法,并得到更好的意见...
前几天写了篇文章,就是用css来实现三角箭头,虽然达到需要的效果了,但还是有一...
CSS3 Patterns Gallery 这个CSS3模式库展示了各种使用纯 CSS3 实现的网页背景效...
head标签学习 网页标题标签 titleHTML学习/title !-- 告诉浏览器我们需要什么标...
我们在不久前刚刚结束了一个 关于 WorkManager 的 MAD Skills 系列课程。在系列...
启动Dreamweaver 之后,第一次更改或删除指向本地文件夹中文件的链接时, Dreamw...
一、CSS变量带来的质变 CSS变量带来的提升绝不仅仅是节约点CSS代码,以及降低CSS...