有關HTML5頁面在iPhoneX適配問題

1. iPhoneX的介紹
屏幕尺寸
我們熟知的iPhone系列開發(fā)尺寸概要如下:
△ iPhone各機型的開發(fā)尺寸
轉(zhuǎn)化成我們熟知的像素尺寸:
△ 每個機型的多維度尺寸
倍圖其實就是像素尺寸和開發(fā)尺寸的倍率關系,但這只是外在的表現(xiàn)。倍圖核心的影響因素在于PPI(DPI),了解屏幕密度與各尺寸的關系有助于我們深度理解倍率的概念:《基礎知識學起來!為設計師量身打造的DPI指南》
iPhone8在本次升級中,屏幕尺寸和分辨率都遺傳了iPhone6以后的優(yōu)良傳統(tǒng);
然而iPhone X 無論是在屏幕尺寸、分辨率、甚至是形狀上都發(fā)生了較大的改變,下面以iPhone 8作為參照物,看看到底iPhone X的適配我們要怎么考慮。
我們看看iPhone X尺寸上的變化:
2. iPhoneX的適配---安全區(qū)域(safe area)
蘋果對于 iPhone X 的設計布局意見如下:
核心內(nèi)容應該處于 Safe area 確保不會被設備圓角(corners),傳感器外殼(sensor housing,齊劉海) 以及底部的 Home Indicator 遮擋。也就是說 我們設計顯示的內(nèi)容應該盡可能的在安全區(qū)域內(nèi);
3. iPhoneX的適配---適配方案viewport-fit 3.1 PhoneX的適配,在iOS 11中采用了viewport-fit的meta標簽作為適配方案;viewport-fit的默認值是auto。
viewport-fit取值如下:
auto | 默認:viewprot-fit:contain;頁面內(nèi)容顯示在safe area內(nèi) |
cover | viewport-fit:cover,頁面內(nèi)容充滿屏幕 |
viewport-fit meta標簽設置(cover時)
<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, viewport-fit=cover">
3.2 css constant()函數(shù) 與safe-area-inset-top &safe-area-inset-left &safe-area-inset-right &safe-area-inset-bottom的介紹
如上圖所示 在iOS 11中的WebKit包含了一個新的CSS函數(shù)constant(),以及一組四個預定義的常量:safe-area-inset-left,safe-area-inset-right,safe-area-inset-top和safe-area-inset-bottom。當合并一起使用時,允許樣式引用每個方面的安全區(qū)域的大小。
3.1當我們設置viewport-fit:contain,也就是默認的時候時;設置safe-area-inset-left,safe-area-inset-right,safe-area-inset-top和safe-area-inset-bottom等參數(shù)時不起作用的。
3.2當我們設置viewport-fit:cover時:設置如下
body { padding-top: constant(safe-area-inset-top); //為導航欄+狀態(tài)欄的高度 88px padding-left: constant(safe-area-inset-left); //如果未豎屏時為0 padding-right: constant(safe-area-inset-right); //如果未豎屏時為0 padding-bottom: constant(safe-area-inset-bottom);//為底下圓弧的高度 34px }
4. iPhoneX的適配---高度統(tǒng)計
viewport-fit:cover + 導航欄
5.iPhoneX的適配---媒體查詢
注意這里采用的是690px(safe area高度),不是812px;
@media only screen and (width: 375px) and (height: 690px){ body { background: blue; } }
6.iphoneX viewport-fit
問題總結
1.關于iphoneX 頁面使用了漸變色時;如果viewport-fit:cover;
1.1在設置了背景色單色和漸變色的區(qū)別,如果是單色時會填充整個屏幕,如果設置了漸變色 那么只會更加子元素的高度去渲染;而且頁面的高度只有690px高度,上面使用了padding-top:88px;
body固定為:
<body><div class="content">this is subElement</div></body>
1.單色時:
* { padding: 0; margin: 0; } body { background:green; padding-top: constant(safe-area-inset-top); //88px /*padding-left: constant(safe-area-inset-left);*/ /*padding-right: constant(safe-area-inset-right);*/ /*padding-bottom: constant(safe-area-inset-bottom);*/ }
2.漸變色
* { padding: 0; margin: 0; } body { background:-webkit-gradient(linear, 0 0, 0 bottom, from(#ffd54f), to(#ffaa22)); padding-top: constant(safe-area-inset-top); //88px /*padding-left: constant(safe-area-inset-left);*/ /*padding-right: constant(safe-area-inset-right);*/ /*padding-bottom: constant(safe-area-inset-bottom);*/ }
解決使用漸變色 仍舊填充整個屏幕的方法;CSS設置如下
<!DOCTYPE html> <html> <head> <meta name="viewport" content="initial-scale=1, viewport-fit=cover"> <title>Designing Websites for iPhone X: Respecting the safe areas</title> <style> * { padding: 0; margin: 0; } html, body { height: 100%; } body { padding-top: constant(safe-area-inset-top); padding-left: constant(safe-area-inset-left); padding-right: constant(safe-area-inset-right); padding-bottom: constant(safe-area-inset-bottom); } .content { background: -webkit-gradient(linear, 0 0, 0 bottom, from(#ffd54f), to(#ffaa22)); width: 100%; height: 724px; } </style> </head> <body> <div class="content">this is subElement</div> </body> </html>
2.頁面元素使用了固定定位的適配即:{position:fixed;}
2.1 子元素頁面固定在底部時;使用viewport-fit:contain時;可以看到bottom:0時只會顯示在安全區(qū)域內(nèi);
<!DOCTYPE html> <html> <head> <meta name="viewport" content="initial-scale=1"> <!--<meta name="viewport" content="initial-scale=1, viewport-fit=cover">--> <title>Designing Websites for iPhone X: Respecting the safe areas</title> <style> * { padding: 0; margin: 0; } /*html,body {*/ /*height: 100%;*/ /*}*/ body { background: grey; /*padding-top: constant(safe-area-inset-top);*/ /*padding-left: constant(safe-area-inset-left);*/ /*padding-right: constant(safe-area-inset-right);*/ /*padding-bottom: constant(safe-area-inset-bottom);*/ } .top { width: 100%; height: 44px; background: purple; } .bottom { position: fixed; bottom: 0; left: 0; right: 0; height: 44px; color: black; background: green; } </style> </head> <body> <div class="top">this is top</div> <div class="bottom">this is bottom</div> </body> </html>
2.1 子元素頁面固定在底部時;使用viewport-fit:cover時;可以看到bottom:0時只會顯示在安全區(qū)域內(nèi);
添加html,body {width:100%;heigth:100%}
圖1:
* { padding: 0; margin: 0; } html,body { height: 100%; } body { background: grey; padding-top: constant(safe-area-inset-top); padding-left: constant(safe-area-inset-left); padding-right: constant(safe-area-inset-right); padding-bottom: constant(safe-area-inset-bottom); } .top { width: 100%; height: 44px; background: purple; } .bottom { position: fixed; bottom: 0; left: 0; right: 0; height: 44px; color: black; background: green; }
圖2:
* { padding: 0; margin: 0; } html,body { height: 100%; } body { background: grey; padding-top: constant(safe-area-inset-top); padding-left: constant(safe-area-inset-left); padding-right: constant(safe-area-inset-right); /*padding-bottom: constant(safe-area-inset-bottom);*/ } .top { width: 100%; height: 44px; background: purple; } .bottom { position: fixed; bottom: 0; left: 0; right: 0; height: 44px; color: black; background: green; }
2.3 關于alertView彈框 遮罩層的解決方案
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <!--<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">--> <meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, viewport-fit=cover"> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <title>alertView</title> <script data-res="eebbk"> document.documentElement.style.fontSize = window.screen.width / 7.5 + 'px'; </script> <style> * { margin: 0; padding: 0; } html,body { width: 100%; height: 100%; } body { font-size: 0.32rem; padding-top: constant(safe-area-inset-top); padding-left: constant(safe-area-inset-left); padding-right: constant(safe-area-inset-right); padding-bottom: constant(safe-area-inset-bottom); } .content { text-align: center; } .testBut { margin: 50px auto; width: 100px; height: 44px; border: 1px solid darkgray; outline:none; user-select: none; background-color: yellow; } </style> <link href="alertView.css" rel="stylesheet" type="text/css"> </head> <body> <section class="content"> <button class="testBut" onclick="showLoading()">彈框加載</button> </section> <script type="text/javascript" src="alertView.js"></script> <script> function showLoading() { UIAlertView.show({ type:"input", title:"溫馨提示", //標題 content:"VIP會員即將到期", //獲取新的 isKnow:false }); var xx = new UIAlertView(); console.log(xx); } </script> </body> </html>
總結
以上所述是小編給大家介紹的有關HTML5頁面在iPhoneX適配問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
iPhoneX怎么看序列號?蘋果iPhoneX查看序列號的三種方法
iPhoneX怎么看序列號?這篇文章主要介紹了蘋果iPhoneX查看序列號的三種方法,需要的朋友可以參考下2017-11-22iPhone X手機電池不耐用怎么辦?iPhoneX啟用黑暗模式提升電池續(xù)航
iPhone X手機電池不耐用怎么辦?是很多iPhone X用戶都想知道的問題,今天腳本之家小編就教大家iPhoneX啟用黑暗模式提升電池續(xù)航的方法,3小時可省電近60%,讓你的iPhone X手2017-11-22iPhone X怎么切換/退出應用?蘋果iPhoneX切換關閉APP方法
自從iPhoneX取消傳統(tǒng)home鍵后,很多朋友問iPhone X怎么切換/退出應用?這篇文章主要介紹了蘋果iPhoneX切換關閉APP方法,需要的朋友可以參考下2017-11-21iPhone X怎么使用?10個常用的iPhone X使用技巧
iPhone X上市已經(jīng)有了一段時間了,很多朋友還是不太會使用,小編就為大家?guī)?0個常用的iPhone X使用技巧,一起看看吧2017-11-14- 取消了HOME鍵的iPhone X怎么回到主界面呢?這篇文章主要介紹了蘋果X返回主頁的兩種方法,一起來看吧2017-11-14
iphoneX王者榮耀誤觸退出怎么辦?iphoneX王者榮耀誤操作解決方法
iphoneX王者榮耀誤觸退出怎么辦?很多朋友買了iphoneX后使用中發(fā)現(xiàn)王者榮耀誤觸退出,找不到游戲了,下文小編就為大家?guī)斫鉀Q辦法,一起看看吧2017-11-13iPhone X續(xù)航怎么樣?iPhone X為什么耗電快
iPhone X續(xù)航怎么樣?需要一天一充嗎?下文小編就為大家?guī)碓敿毥榻B,一起看看吧2017-11-13iPhone X怎么關機? 蘋果iPhone X關機方法和強制關機技巧
有不少果粉開始不知道蘋果X怎么關機與強制關機等操作,其實方法很簡單,需要的朋友趕緊看看吧2017-11-12iphone X如何關閉后臺?蘋果iphone X關閉軟件后臺方法介紹
iphone X如何關閉后臺?是很多iphoneX用戶都想知道的問題,今天腳本之家小編就給大家介紹一下蘋果iphone X關閉軟件后臺的方法步驟,希望對大家有所幫助2017-11-10iPhone X深空灰和銀色哪個好看 蘋果X銀色和黑色圖賞對比
作為近年來設計改變最為明顯的蘋果手機,iPhone X登場的顏色款式卻罕見地少,僅僅提供的深空灰和銀色都是以往常見的顏色,很多朋友在糾結iPhone X深空灰和銀色哪個更好看?2017-11-23