摘要:是阿里團隊開發的前端適配方案,也是用的的方法。那么第一種方法其實已經能解決前端適配問題了,為什么阿里還要開發一個呢在第一種方法中,時沒有任何問題,但是在或者更高的手機屏幕上,因為物理像素的增加,存在小于的顯示空間。
話說我剛工作的時候,就開始用rem了,過了沒多久,接觸到了flexible,系統化且支持iOS的retina屏迅速征服了我,最近又看到了大漠大神的vw。所以本文想完成一篇一站式的文章,可以系統的了解前端適配的演進。閑話少敘,馬上開始。1. 什么是前端適配
從UI展現層面上:
我們期望不同尺寸的設備,頁面可以自適應的展示或者進行等比縮放,從而在不同的尺寸的設備下看起來協調或者差不多。
從代碼實現層面上:
我們希望前端適配可以用用盡可能簡潔的代碼來實現。最好一套代碼實現兼容所有設備,而不是對每個或每種設備都寫一套方案,不是次次都選用最無奈的方案(Android和iOS分開編寫)。
如果你了解這些關鍵字,那么這段大可以跳過,如果后面遇到了問題,感覺有些疑惑,也可以再回來查閱。
2.1 Viewport/視口通俗的講,移動設備上的viewport就是設備的屏幕上能用來顯示我們的網頁的那一塊區域[1],但不一定是我們可見的區域。具體來說,分為以下三種。
2.1.1 Visual ViewportVisual Viewport: 可見視口。就是移動設備上可以被我們看見的部分。寬度在移動端通過window.innerWidth獲得(僅限移動端,PC上哪怕是chrome模擬也會有不同的結果)。2.2.2 Layout Viewport
Layout Viewport: 布局視口。
如果把PC上的頁面放到移動端,以iphone8為例,如果只展示為可見視口的寬度(375px),那么頁面會被壓縮的特別窄而顯示錯亂,所以移動瀏覽器就決定默認情況下把viewport設為一個較寬的值,比如980px,這樣的話即使是那些為桌面設計的網站也能在移動瀏覽器上正常顯示了。[1]
而事實上,我們一般看不到如上圖這樣出現橫向滾動條的界面;在手機上訪問頁面時,往往是下圖的樣子:
這是由于頁面body寬度設置了100%而沒有指定一個具體的寬度導致的,從而使頁面被等比縮放了。由于用戶可以縮放,所以還算能正常瀏覽。
2.2.3 Ideal ViewportIdeal Viewport:理想視口,其實就是設備的可見區域,和可見視口一致。
設置Ideal Viewport的好處是,只要按照Ideal Viewport來設計樣式稿,用戶就不用能最完美的查看網站的內容——既不用左右滑動,也不用放大縮小。
設置理想視口:
這段代碼的意思是將布局視口的寬度設置為設備寬度,初始縮放比例為1,最大縮放比例為1,用戶不能縮放。
2.2 像素 2.2.1 物理像素物理像素:一個物理像素是顯示器(手機屏幕)上最小的物理顯示單元,在操作系統的調度下,每一個設備像素都有自己的顏色值和亮度值。[2]2.2.2 設備獨立像素
設備獨立像素:又稱為CSS像素,就是我們日常代碼中使用的像素。瀏覽器內的一切長度都是以CSS像素為單位的,CSS像素的單位是px。2.2.3 設備像素比
設備像素比(簡稱dpr)定義了物理像素和設備獨立像素的對應關系。比如說對于iOS的retina屏,一個設備獨立像素就對應著4個物理像素。這樣的設計可以使畫面更加清晰銳利,如下圖:
OK,LongLongAgo的前綴之后,終于到了正題。回到我們最開始的初心:我們只是想要通過一套代碼,實現一個可以在不同頁面尺寸上展示差不多的頁面。在這一塊,現在主要有三種方案。
3.1 Rem的解決方案DPR一致時,px在不同的屏幕尺寸上會展示為定寬,這就導致我們的頁面可能會出現滾動條或者占不滿的情況。而通過rem來設置div的寬高,可以保證頁面可以通過調整html的font-size來整體放大或者縮小,從而達到不管屏幕寬度是多少,頁面都能完美展示的效果。
例如,針對750*1334的設計稿:
這樣,所有的設備的寬度都是7.5rem,只需要把設計稿上的px值統一除以100,就可以得到相應的rem值了。
網易也采用的這種方法。
3.2 Flexible.jsFlexible是阿里團隊開發的前端適配方案,也是用的rem的方法。那么第一種方法其實已經能解決前端適配問題了,為什么阿里還要開發一個Flexible呢?
在第一種方法中,dpr=1時沒有任何問題,但是在dpr=2或者更高的手機屏幕上,因為物理像素的增加,存在小于1px的顯示空間。如果采用第一種方法,因為它統一對scale設置為1,那么我們假如想要實現0.5px, 就只能通過transform的方式。如果有多個這樣的樣式,代碼就會變得很麻煩。
.scale{ position: relative; } .scale:after{ content:""; position: absolute; bottom:0px; left:0px; right:0px; border-bottom:1px solid #ffffd; -webkit-transform:scaleY(.5); -webkit-transform-origin:0 0; }
因此,阿里的flexible方案充分考慮了這種情況,動態的設置了fontsize和scale, 從而使得CSS中的1px等于物理像素中的1px,在IOS下得到最清晰的體驗。
if (!dpr && !scale) { var isAndroid = win.navigator.appVersion.match(/android/gi); var isIPhone = win.navigator.appVersion.match(/iphone/gi); var devicePixelRatio = win.devicePixelRatio; if (isIPhone) { // iOS下,對于2和3的屏,用2倍的方案,其余的用1倍方案 if (devicePixelRatio >= 3 && (!dpr || dpr >= 3)) { dpr = 3; } else if (devicePixelRatio >= 2 && (!dpr || dpr >= 2)){ dpr = 2; } else { dpr = 1; } } else { // 其他設備下,仍舊使用1倍的方案 dpr = 1; } scale = 1 / dpr; } 最終在iphone8下頁面的header被設置為:
具體的大家可以看《使用Flexible實現手淘H5頁面的終端適配》
另外需要指出的一點是:Flexible將頁面分成了100份,頁面的寬度是10rem,對于750的設計稿,我們需要用相應的px數除以75來得到。手動計算是愚蠢的,不同的編譯器都可以下載pix2rem插件(可以直接寫px然后自動轉換為相應的rem值),直接使用sass或者postcss打包也能達到同樣的功能。
總結一下上面兩種rem方法,主要思想為:
根據dpr的值來修改html的font-size,從而使用rem實現等比縮放
根據dpr的值來修改viewport實現1px的線
但是Flexible也有它的局限性,具體表現為:
不能與響應式布局兼容
對Android沒有做處理,導致1px和backgroudImage還要額外做處理的問題[4]
所以我們有了第三種解決方案——vw。
3.3 vwvw是基于Viewport視窗的長度單位,在CSS3中和Viewport相關的單位有四個,分別為vw、vh、vmin和vmax。
vw: 是Viewport"s width的簡寫,1vw等于window.innerWidth的1%
vh:和vw類似,是Viewport"s height的簡寫,1vh等于window.innerHeihgt的1%
vmin: vmin的值是當前vw和vh中較小的值
vmax: vmax的值是當前vw和vh中較大的值
其實vw的方案的寫法和flexible方案的寫法一致——因為flexible其實就是用hack的手段模擬了vw的實現而已。
具體寫法:針對750px的設計稿,將相應的px值除以7.5就是vw的值。
因為此方法不會改變可見視口的寬度,所以可以和media query通用了,另外,也支持了Android上高分辨率屏的展示。
盡管在某些Android機型上還存在兼容問題,我們也可以使用Viewport Units Buggyfill,具體見《如何在Vue項目中使用vw實現移動端適配》
總結正如大漠所說,flexible模擬vw的時代已經過去,真正的酋長vw已經歸來。
參考文檔:《移動前端開發之viewport的深入理解》
《移動端高清、多屏適配方案》
《再聊移動端頁面的適配》
《基于淘寶彈性布局方案lib-flexible的問題研究》
《如何在Vue項目中使用vw實現移動端適配》
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/52169.html
摘要:是阿里團隊開發的前端適配方案,也是用的的方法。那么第一種方法其實已經能解決前端適配問題了,為什么阿里還要開發一個呢在第一種方法中,時沒有任何問題,但是在或者更高的手機屏幕上,因為物理像素的增加,存在小于的顯示空間。 話說我剛工作的時候,就開始用rem了,過了沒多久,接觸到了flexible,系統化且支持iOS的retina屏迅速征服了我,最近又看到了大漠大神的vw。所以本文想完成一篇一...
摘要:是阿里團隊開發的前端適配方案,也是用的的方法。那么第一種方法其實已經能解決前端適配問題了,為什么阿里還要開發一個呢在第一種方法中,時沒有任何問題,但是在或者更高的手機屏幕上,因為物理像素的增加,存在小于的顯示空間。 話說我剛工作的時候,就開始用rem了,過了沒多久,接觸到了flexible,系統化且支持iOS的retina屏迅速征服了我,最近又看到了大漠大神的vw。所以本文想完成一篇一...
摘要:經常我們在瀏覽器上調試的好好的,但是到了移動端就會有各種奇特的適配問題最經常遇見莫過于中文字稍微偏上了。為什么中文本偏上文本都會有一個內容區域,這個區域就是我們選中文本時展示的區域。 在日常工作中,經常會遇到圖片+文字+背景色的設計稿實現。經常我們在Chrome瀏覽器上調試的好好的,但是到了移動端就會有各種奇特的適配問題——最經常遇見莫過于Android中文字稍微偏上了。在iOS和An...
摘要:經常我們在瀏覽器上調試的好好的,但是到了移動端就會有各種奇特的適配問題最經常遇見莫過于中文字稍微偏上了。為什么中文本偏上文本都會有一個內容區域,這個區域就是我們選中文本時展示的區域。 在日常工作中,經常會遇到圖片+文字+背景色的設計稿實現。經常我們在Chrome瀏覽器上調試的好好的,但是到了移動端就會有各種奇特的適配問題——最經常遇見莫過于Android中文字稍微偏上了。在iOS和An...
閱讀 3019·2021-11-24 10:21
閱讀 1588·2021-10-11 10:57
閱讀 2803·2021-09-22 15:24
閱讀 2658·2021-09-22 14:58
閱讀 2331·2019-08-30 13:16
閱讀 3478·2019-08-29 13:05
閱讀 3411·2019-08-29 12:14
閱讀 3440·2019-08-27 10:55