首頁 > web前端 > css教學 > css如何實現適配iphone全面屏

css如何實現適配iphone全面屏

王林
發布: 2020-05-21 09:09:31
轉載
3655 人瀏覽過

css如何實現適配iphone全面屏

一、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

<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入門基礎教學

以上是css如何實現適配iphone全面屏的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:jb51.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板