作者:胡宸宸 | 来源:互联网 | 2020-09-15 17:15
css实现适配iphone全面屏的方法是:1、通过mediaquery方式来实现;2、可以通过CSS函数来实现,具体方法是:在meta标签中加入viewport-fitcover。
一、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函数
苹果在推出全面屏之后提供的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
css写法,不支持env、constant的浏览器会忽略此样式
.fixed-bottom{
bottom: 0;
bottom: constant(safe-area-inset-bottom);
bottom: env(safe-area-inset-bottom);
}
推荐教程:CSS入门基础教程
以上就是css如何实现适配iphone全面屏的详细内容,更多请关注 第一PHP社区 其它相关文章!