css如何实现适配iphone全面屏

 4514

css如何实现适配iphone全面屏

一、media query方式

  1. /*iPhone X 适配*/
  2. @media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) {
  3.     .fixed-bottom{
  4.         bottom: 37px;
  5.     }
  6. }
  7. /*iPhone XS max 适配*/
  8. @media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio:3) {
  9.     .fixed-bottom{
  10.         bottom: 37px;
  11.     }
  12. }
  13. /*iPhone XR max 适配*/
  14. @media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio:2) {
  15.     .fixed-bottom{
  16.         bottom: 37px;
  17.     }
  18. }

存在的问题:在微信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

  1. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, viewport-fit=cover">

css写法,不支持env、constant的浏览器会忽略此样式

  1. .fixed-bottom{
  2.     bottom: 0;
  3.     bottom: constant(safe-area-inset-bottom);
  4.     bottom: env(safe-area-inset-bottom);
  5. }

以上就是css如何实现适配iphone全面屏的详细内容,希望对大家有所启发。



本文网址:https://www.zztuku.com/index.php/detail-7800.html
站长图库 - css如何实现适配iphone全面屏
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐