国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

rem, vw, 還是...? 各憑本事的移動端適配方案

wangbinke / 2794人閱讀

摘要:另一種就是不縮放,對等問題多帶帶引入處理方案。彩蛋部分相信大多數(shù)同學(xué)也是有想法在實際開發(fā)中把融入到現(xiàn)有的移動端適配方案中的。

前言

2018年最后的法定假期都已經(jīng)結(jié)束了,我相信大部分正在進行或曾經(jīng)進行過移動端頁面開發(fā)的同學(xué)都或多或少的了解過使用rem進行移動端頁面適配的方案以及使用vw的方案,(沒了解過的同學(xué)可以參見大漠老師的這兩篇文章 使用Flexible實現(xiàn)手淘H5頁面的終端適配和再聊移動端頁面的適配)也面臨過在不同適配方案間進行抉擇的思考,我個人最近對于移動端適配方案也進行了一輪重新的研究,期間,對各種適配方案也有一些自己的見解,正好記錄下來與大家一起分享。

vw與rem方案中的一些思考 所以,移動端適配 = vw or rem ?

當然不是。并不是所有場景下的移動端頁面都適合采用vw或rem的方案,這類方案的本質(zhì)是布局等比例的縮放,讓頁面在不同尺寸的屏幕下有類似于矢量圖片縮放的效果,即保證頁面各元素之間位置尺寸的比例關(guān)系,并讓元素可以清晰地展現(xiàn)。
這樣的方案更適合于視覺組件種類較多,視覺設(shè)計對元素位置的相對關(guān)系依賴較強的移動端頁面。其實大部分頁面都可以使用rem或vw的方案進行適配,但對于文本內(nèi)容較多,或者說希望引導(dǎo)用戶沉浸瀏覽的頁面,我個人并不推薦使用等比縮放的方案,至少并不推薦完全使用等比縮放的方案,對于文本內(nèi)容還是應(yīng)該直接使用px這種絕對長度單位,畢竟在大屏手機上用戶希望看到的是更多的內(nèi)容而不是更大的內(nèi)容。實際上很多這類的網(wǎng)站也確實是直接使用px結(jié)合flex等布局方式進行移動端適配的,這個在后面討論具體技術(shù)方案的時候我會舉幾個例子。

rem方案到底在做什么?

在各種rem適配方案的實現(xiàn)中,有兩個核心的點

設(shè)置(可以根據(jù)dpr縮放viewport,也可以直接使用1倍的視口大小)

根據(jù)當前布局的寬度(通常是viewport寬度, 也可以是被限制的最大/最小布局寬度)來設(shè)置html元素的font-size

之前我已經(jīng)提到過,vw和rem的方案的本質(zhì)都是“等比例縮放”,因為vw和rem都是相對長度單位(relative length unit),可以很好的滿足這個需求。區(qū)別是vw是viewport width的1%,而rem是html元素的font-size。當我們讓html元素的font-size與viewport width產(chǎn)生了關(guān)聯(lián)后,rem就可以模擬出使用vw進行布局的效果了。所以在rem方案中,我們只是在把rem當做是vw的影子。寫作rem,讀作vw...(劇情似乎狗血起來了... rem: 當然是選擇原諒你們啊)

那直接用vw不就完事兒了嗎?

且慢,當初之所以使用rem的方案流行開來正是因為在那時viewport units的瀏覽器支持程度不甚理想(IOS 8+, Android 4.4+ 參見viewport units的caniuse)。而相比較之下rem就好多了(IOS 4.1+, Android 2.1+ 參見caniuse),所以對于vw,在當時的大環(huán)境下前端想說愛你不容易。

我想這時候有人要說了:“醒醒兄弟 已經(jīng)8102年了!”
是的,8102年都快要過去了,對于兼容性要求不是特別高的情況下vw也算是可以見天日了,并且也有一些針對vw的補丁方案,但還有一個問題我們要稍微討論一下...

vw可以完全替代rem嗎?

回答依舊是否定的。單純使用vw進行布局不能限制布局的寬度,對于有這個需求的場景至少還是需要將vw和rem混用來處理邊界情況。下文也會更詳細地提到這種方案,這里先按下不表。

現(xiàn)有生產(chǎn)環(huán)境中移動端適配方案的一點總結(jié)

當我們在苦苦地尋找適合自己的道路時,不妨先抬頭看看別人是怎么做的。那么現(xiàn)實世界里各家互聯(lián)網(wǎng)公司的移動端頁面都采用了什么樣的適配方案呢?有沒有一些比較有特色的絕活兒呢?以下我按照頁面實際使用的css長度單位作為劃分標準,為大家舉一些栗子。

px方案

就像開篇提到的,并不是說移動端就一定要使用相對長度單位,傳統(tǒng)的響應(yīng)式布局依然是很好的選擇,尤其在新聞,社區(qū)等可閱讀內(nèi)容較多的場景直接使用px單位可以營造更好地體驗。px方案可以讓大屏幕手機展示出更多的內(nèi)容,更符合人們的閱讀習(xí)慣。采用這種方案的網(wǎng)站有:

騰訊

移動端首頁主要是新聞內(nèi)容,需要更好的閱讀體驗,適合直接使用px進行布局。

知乎

知乎也是比較典型的追求閱讀體驗的場景,不出意外的也是直接使用px。

點評

視覺元素較豐富,依舊采用了px方案,頁面基本是flex布局,適配效果很好

頭條

頭條的這個方案有點特色,依然會設(shè)置html元素的font-size也會加上data-dpr屬性并且會對viewport進行scale, 但是最終css的輸出還是px,并沒有使用rem,并且會對不同dpr下的樣式多帶帶定義,如下圖所示:


這樣可以解決1px border的問題,文字大小也不會隨屏幕尺寸變動(畢竟文本內(nèi)容較多),雖然我暫時沒找到使用到rem的地方,但確實可以在需要的時候?qū)μ厥庠刈鰎em方案的布局,不過這種方案應(yīng)該會造成css文件大小倍增,而且輸出這樣的css肯定也少不了構(gòu)建流程插件的支持,算是一種特定的解決方案吧。

看到這里你以為最終輸出px就不能做類似于rem/vw的彈性布局了嗎,下面就給大家看一手絕活兒...

淘寶

什么?給我們看了半天文章結(jié)果用的是px?
其實聰明的你一定很快就會發(fā)現(xiàn)在效果上淘寶移動端的適配方案和rem/vw的方案其實是差不多的,元素的樣式都是通過js生成的,雖然單位確實是px,但是方案依舊是以375px寬度的尺寸為基準進行縮放的。原理上應(yīng)該是一種css in js的方案,只不過把rem方案中設(shè)置html元素font-size的過程內(nèi)化到使用js計算元素style的過程中去了。這樣的方案涉及到整體的開發(fā)框架上的統(tǒng)一與支持,并不算是一個特別通用的方案。好處可能是直接使用px單位結(jié)果更為精確。可以說是一手絕活兒了。當然淘寶旗下還是有非常多的產(chǎn)品線的,也未必是同樣的適配方案(比如大漠老師文中的例子),這里只針對這個移動端首頁來說。

rem方案

rem方案可以說是比較成熟了,出鏡率也較高,也就不再贅述了,總的來說rem方案主要分為兩種,一種是縮放viewport的方案,如當年的lib-flexible,可以對1px border等細節(jié)問題較方便的處理,但會影響到media query。另一種就是不縮放viewport,對1px boder等問題多帶帶引入處理方案。然后對于基準尺寸下的html元素fong-size也有很多不同的定義方式,這個說起來沒什么標準可言,我就隨便舉幾個例子說明吧:

不縮放viewport

(以下說明的rem與px的對應(yīng)關(guān)系都是在屏幕寬度為375px的情況下)

馬蜂窩
1rem = 37.5px

小米
1rem = 52.0833px

小紅書
1rem = 50px

微博

1rem = 16px
稍微說明下 微博的font-size是根據(jù)media query來生成的

縮放viewport

(以下說明的rem與px的對應(yīng)關(guān)系都是在屏幕寬度為375px, viewport scale 0.5的情況下)

點評
1rem = 100px

B站主站
1rem = 46.875px

搜狐
1rem = 75px

vw方案

來了,終于來了!前面說了這么多關(guān)于vw的問題,到底有沒有現(xiàn)有的產(chǎn)品在大規(guī)模的使用vw的方案呢?兼容方案又是怎么做的呢?

京東

京東的移動端首頁采用了vw+rem的布局方式,元素布局上依然使用rem單位,沒有縮放viewport, html元素的font-size則使用vw + px fallback的形式,并且使用media query來限制布局寬度,如下圖所示

正常情況下:

邊界情況下

網(wǎng)易

網(wǎng)易的方案和京東基本相同,沒有縮放viewport,使用media query,只處理html元素的font-size,并限制布局寬度。

餓了么

餓了么也是采用的vw+rem的方案,不過對viewport進行了縮放,也沒有限制布局寬度,html元素的font-size依然由px指定,但是具體元素的布局上使用vw + px fallbak的形式,如下圖所示:

可以看到,使用上述兩種vw+rem的方案對現(xiàn)有的rem方案的改動都不會很大,都采用了vw + fallback的方式,兼容性問題得到了保證,只是餓了么的方案可能更需要構(gòu)建過程中的插件支持(關(guān)于這個,后面我給你們解釋解釋什么叫驚喜)。這樣來看,對于大漠老師提出的vw方案中使用viewport-units-buggyfill庫進行兼容的做法,我個人就并不是很推薦了,因為該庫使用了css content屬性進行兼容處理,官方文檔中就指出了對部分瀏覽器的img標簽有影響 ,需要全局引入一條css規(guī)則。且對于需要正常使用content的情況(如:圖標字體)也會引起不可避免的沖突,另外也不支持偽元素的兼容。所以從我個人的角度來說,如果你一定要問我使用怎樣的vw適配方案,我會推薦給你上述兩種vw + rem的方案。

這就是全部了嗎?

當然不是,我只是列舉了幾個比較典型的移動端適配方案,其實在具體實現(xiàn)的細節(jié)上可以自行把握的點還是很多的,適合的終歸才是最好的,那顆銀彈或許不會出現(xiàn),但我們的手中也從未缺少過利器。

彩(an)蛋(li)部分

相信大多數(shù)同學(xué)也是有想法在實際開發(fā)中把vw融入到現(xiàn)有的移動端適配方案中的。如我上述提到的兩種vw+rem方案,只修改html元素font-size的方案對于已經(jīng)在使用rem方案的同學(xué)來說改動的成本并不大,只需要在原本的media query 里(或js生成style時)在font-size: *px后面加上font-size: *vw就可以了,如需限制布局寬度則需多加一點判斷。

而對于餓了么那種在使用到長度單位時同時輸出rem+vw的方式,肯定是要通過一點額外的插件來做了。如果你和我一樣剛好在使用Stylus作為css預(yù)處理器,那我專門寫了一個Stylus的插件用來幫你處理這個問題。
這個插件可以讓你在開發(fā)流程使用px書寫css, 和現(xiàn)有的部分插件不同的是,它同時支持多種適配方案的輸出,目前支持rem,純vw方案以及剛才提到的vw+rem方案的輸出。并且對不希望轉(zhuǎn)換px的場景做了很方便的處理。也就是說,如果你現(xiàn)在使用rem方案,可以直接替換使用該插件,當你需要切換到vw或vw+rem方案時基本可以做到無縫切換。

具體的使用方式和示例請參見pandaGao/stylus-px-to-relative-unit

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/113996.html

相關(guān)文章

  • rem, vw, 還是...? 各憑本事移動適配方案

    摘要:另一種就是不縮放,對等問題單獨引入處理方案。彩蛋部分相信大多數(shù)同學(xué)也是有想法在實際開發(fā)中把融入到現(xiàn)有的移動端適配方案中的。 前言 2018年最后的法定假期都已經(jīng)結(jié)束了,我相信大部分正在進行或曾經(jīng)進行過移動端頁面開發(fā)的同學(xué)都或多或少的了解過使用rem進行移動端頁面適配的方案以及使用vw的方案,(沒了解過的同學(xué)可以參見大漠老師的這兩篇文章 使用Flexible實現(xiàn)手淘H5頁面的終端適配和再...

    tianren124 評論0 收藏0
  • 移動適配方案

    摘要:業(yè)務(wù)環(huán)境是決定整體項目的適配方案的核心因素。而淘寶的主站和類似,分為移動端頁面和端頁面,端頁面同樣有著左右的留白,這也是為了讓用戶能夠在寬屏的時候?qū)⒆⒁饬性谥虚g區(qū)域。 移動端適配方案 移動端適配方案是一個老生常談的話題,但是對于不同的項目、不同的業(yè)務(wù)場景可能會需要不同的適配方案來進行移動端適配,向下兼容的baseline也需要提前訂好。 整體寬高 其實移動端適配就和下面的玩具一樣,...

    feng409 評論0 收藏0
  • H5 深度解析

    摘要:這個問題的解決方案有很多,個人覺得最簡單方面的還是大漠大大的一種解決方案。 先科普一下,HTML5并不是一項技術(shù),而是一個標準。所以其實要么我們是作為理論派討論HTML5標準,要么是作為實踐派討論HTML5標準在某瀏覽器的應(yīng)用。H5 實際上是一個解決方案,一個看起來酷炫的移動端onepage網(wǎng)站的解決方案 移動端的適配方案 rem適配 優(yōu)點: 1. 引用簡單,布局簡便 ...

    Cympros 評論0 收藏0
  • 不要再問我移動適配問題了

    摘要:不要再問我的問題系列一不要再問我的指向問題了二不要再問我跨域的問題了移動端適配的問題,一般來說我們都不會去深究,因為這種東西都是配置一次就再也不用管的了,接到設(shè)計圖就按照祖?zhèn)魈茁窋]就完事了。 不要再問我XX的問題系列:一、不要再問我this的指向問題了二、不要再問我跨域的問題了 移動端適配的問題,一般來說我們都不會去深究,因為這種東西都是配置一次就再也不用管的了,接到設(shè)計圖就按照祖?zhèn)?..

    Airy 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<