成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

rem, vw, 還是...? 各憑本事的移動(dòng)端適配方案

wangbinke / 2796人閱讀

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

前言

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

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

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

rem方案到底在做什么?

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

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

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

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

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

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

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

vw可以完全替代rem嗎?

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

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

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

px方案

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

騰訊

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

知乎

知乎也是比較典型的追求閱讀體驗(yàn)的場(chǎng)景,不出意外的也是直接使用px。

點(diǎn)評(píng)

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

頭條

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


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

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

淘寶

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

rem方案

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

不縮放viewport

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

馬蜂窩
1rem = 37.5px

小米
1rem = 52.0833px

小紅書
1rem = 50px

微博

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

縮放viewport

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

點(diǎn)評(píng)
1rem = 100px

B站主站
1rem = 46.875px

搜狐
1rem = 75px

vw方案

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

京東

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

正常情況下:

邊界情況下

網(wǎng)易

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

餓了么

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

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

這就是全部了嗎?

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

彩(an)蛋(li)部分

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

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

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

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/113996.html

相關(guān)文章

  • rem, vw, 還是...? 各憑本事移動(dòng)適配方案

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

    tianren124 評(píng)論0 收藏0
  • 移動(dòng)適配方案

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

    feng409 評(píng)論0 收藏0
  • H5 深度解析

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

    Cympros 評(píng)論0 收藏0
  • 不要再問我移動(dòng)適配問題了

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

    Airy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<