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

資訊專欄INFORMATION COLUMN

對(duì)于頁面適配,你應(yīng)該使用px還是rem

Jochen / 1600人閱讀

摘要:第一種情況也不討論了,通過斷點(diǎn)適配后,其實(shí)你處理的還是第二種情況。至于移動(dòng)端,支持情況不錯(cuò),可以在生產(chǎn)環(huán)境使用。

css中的單位很多,%px、em、rem,以及比較新的vwvh等。每個(gè)單位都有特定的用途,比如當(dāng)需要設(shè)置一個(gè)矩形的寬高比為16:9,并且隨屏幕寬度自適應(yīng)時(shí),除了用%,其他單位是很難做到的。所以不存在說某個(gè)單位是錯(cuò)誤的,某個(gè)單位是最好的這種說法。

那本文說的頁面適配,指的是同樣的布局,在不同大小的屏幕上怎么進(jìn)行縮放、控制間距、寬高、字號(hào)等大小。

頁面適配的方式有很多:

使用px,結(jié)合Media Query進(jìn)行階梯式的適配;

使用%,按百分比自適應(yīng)布局;

使用rem,結(jié)合html元素的font-size來根據(jù)屏幕寬度適配;

使用vwvh,直接根據(jù)視口寬高適配。

在這些大前提下,還需針對(duì)一些小的細(xì)節(jié)做微調(diào)。比如使用px的時(shí)候,可能在小屏幕中,要對(duì)某個(gè)容器進(jìn)行transform: scale(.8),適當(dāng)縮小處理。使用rem的時(shí)候,需要固定頁面的左右間距為10px等。

所以對(duì)我來說,盡管網(wǎng)上曾對(duì)px、remem等單位的優(yōu)缺點(diǎn)爭(zhēng)論過很多,但我的觀點(diǎn)可能是,具體情況具體分析。有同學(xué)可能要炸了,你這跟沒說有啥區(qū)別?

對(duì),我的意思跟開篇一樣,單論某個(gè)單位的好壞是沒意義的。我們最關(guān)注的是:什么場(chǎng)景中,使用什么單位最合適。

也不賣關(guān)子了,我就直接列一些自己覺得比較好的實(shí)踐方式,這些都是根據(jù)自己多年的開發(fā)經(jīng)驗(yàn)和大量的調(diào)研得到的結(jié)論:

在視覺稿要求固定尺寸的元素上使用px。比如1px線,4px的圓角邊框。

在字號(hào)、(大多數(shù))間距上使用rem。

慎用em。

為什么我標(biāo)題沒提到%、vwvh這幾個(gè)呢?這幾個(gè)都是按比例適配,只不過參考對(duì)象不一樣。

%是參考父容器,vwvh是參考視口。他們的使用場(chǎng)景是非常固定的,比如上文提到的16:9的容器,除了用%,還有更合適的方式嗎?另外,1vw = 1%的視口寬度。所以就真正需要按視口大小適配的時(shí)候再用這個(gè)單位吧,使用場(chǎng)景相對(duì)固定。

接下來我會(huì)詳細(xì)介紹一下這3個(gè)結(jié)論的由來。

為什么慎用em?

em會(huì)疊加計(jì)算。在這個(gè)機(jī)制下太容易犯錯(cuò)了,因?yàn)槟悴恢肋@段css指定的字號(hào)具體是多少。

// HTML

    abc
    def
    abc


// CSS
span {font-size: 1.5em;}

實(shí)際的效果是這樣的:

先要搞清楚em的計(jì)算原理,它是根據(jù)當(dāng)前元素的字號(hào)按比例計(jì)算的。

外層span的字號(hào)是16px(瀏覽器默認(rèn)值),所以1.5em之后是24px。由于字號(hào)是繼承的,導(dǎo)致內(nèi)層span的字號(hào)繼承過來是24px,再經(jīng)過1.5em之后就成了36px

所以,就算要用em的話,盡量不要用在繼承屬性(font-size)上,除非你真的清楚你在做什么!

比如你想根據(jù)字號(hào)自動(dòng)調(diào)整字符間距,可以這么做:

.content {
    font-size: 1rem;
    letter-spacing: .03em;
}

但再仔細(xì)想一下,letter-spacing.content的字號(hào)決定,而它又由html的字號(hào)決定。那為什么letter-spacing不直接用rem呢?

rem vs. px

px是我比較喜歡的一個(gè)單位,簡(jiǎn)單又直接。但理性驅(qū)使,還是要合理考慮使用場(chǎng)景。

px的性質(zhì)決定了它只能用于固定尺寸。也就是說,如果視覺設(shè)計(jì)師規(guī)定,這個(gè)邊框?qū)挾缺仨毷?b>2px。那這種情況下就不需要討論了。

除了固定尺寸用px,其他大部分情況都可以使用rem。

現(xiàn)在考慮一個(gè)實(shí)際的開發(fā)場(chǎng)景,一般來說都是先有視覺稿才能開發(fā)。兩種情況:一、假設(shè)視覺稿按iPhone 6和iPhone 6+,及其他尺寸各出了一份,那你就按照Media Query去適配。二、設(shè)計(jì)師只給你一種機(jī)型的視覺稿,以iPhone 6為例,750x1334,2倍屏下轉(zhuǎn)換后是375x667。

第一種情況也不討論了,通過Media Query斷點(diǎn)適配后,其實(shí)你處理的還是第二種情況。

那第二種的意思是,你要根據(jù)寬度為375px的稿子,擴(kuò)展到適配任意寬度的屏幕。(頁面高度跟業(yè)務(wù)有關(guān),不用關(guān)心,寬度肯定是固定的)

接下來拿到視覺稿如下:

測(cè)量后主要參數(shù)如下:

頁面間距10px

文字間距10px,字號(hào)16px

A高度100px

B高度50px,上間距30px

很快就能寫出HTML結(jié)構(gòu)和CSS。

A. 第一段內(nèi)容
B. 第二段內(nèi)容
body {
    padding: 10px;
    background: #f6f0ee;
}

.box {
    padding: 10px;
    font-size: 16px;
    color: #fff;
    box-sizing: border-box;
}

.box-1 {
    height: 100px;
    background: #1daedc;
}

.box-2 {
    margin-top: 30px;
    height: 50px;
    background: #ddbe97;
}

完美符合要求。

然后視覺開始提要求了,大屏上要把字體放大、間距放大。

這時(shí)候的一個(gè)選擇是,問設(shè)計(jì)師是要適配哪種屏幕,字號(hào)是多少,間距是多少。技術(shù)上再通過Media Query微調(diào)。

@media(min-width: 414px) {
    // 這里不寫了,按視覺要求量化即可
}

另一個(gè)選擇可以反過來做。首先按rem作為字號(hào)、容器高度、外間距的單位。那么代碼可以改為:

html {
    font-size: 16px;
}

.box {
    font-size: 1rem;
}

.box-1 {
    height: 6.25rem;
}

.box-2 {
    margin-top: 1.875rem;
    height: 3.125rem;
}

其他的樣式規(guī)則不變,目前的結(jié)果和之前的是等價(jià)的。如果再加一點(diǎn)魔法,通過Media Query改變iPhone 6+的html字號(hào),其他元素的屬性就會(huì)自動(dòng)變化。

@media(min-width: 414px) {
    html {
        font-size: 17.664px;
    }
}

17.664 = 414 * 16 / 375。

由此可以得到htmlfont-size計(jì)算公式為:fontSize = deviceWidth * 16 / 375;

前提是你的html有這條meta屬性:

至于為何是16px,這個(gè)后面再介紹。所以rem有個(gè)明顯的優(yōu)點(diǎn),它可以通過少量代碼解決大部分問題

如果還存在某些細(xì)節(jié)不夠滿意,那再用Media Query微調(diào)。這種主觀的“好看”、“不好看”,可能注定沒法自動(dòng)化解決吧。

關(guān)于rem兼容性。桌面端的話僅在IE9+支持。vwvh一樣。所以如果要考慮IE8的兼容性,那沒別的選擇只能用px吧。至于移動(dòng)端,支持情況不錯(cuò),可以在生產(chǎn)環(huán)境使用。

html的font-size該如何設(shè)置

由于(大部分)瀏覽器的默認(rèn)字號(hào)為16px,所以一般來說把htmlfont-size歸一化為16px是比較合適的實(shí)踐方式。同時(shí)可以參考這篇文章。

為了大家以后參考方便,我列了一些常用的Media Query斷點(diǎn)(以iPhone 6為基準(zhǔn))。

@media only screen and (min-width: 320px) {
    html {
        font-size: 13.65px;
    }
}

@media only screen and (min-width: 360px) {
    html {
        font-size: 15.36px;
    }
}

@media only screen and (min-width: 375px) {
    html {
        font-size: 16px;
    }
}

@media only screen and (min-width: 390px) {
    html {
        font-size: 16.64px;
    }
}

@media only screen and (min-width: 414px) {
    html {
        font-size: 17.664px;
    }
}

@media screen and (min-width: 640px) {
    html {
        font-size: 27.31px;
    }
}

大家可能還會(huì)看到一些文章中建議把html字號(hào)設(shè)成62.5%。

html {
    font-size: 62.5%;
}

因?yàn)閯偺岬綖g覽器默認(rèn)的字號(hào)為16px,用百分比換算后等于10px,所以CSS中的rem是相對(duì)于10px來計(jì)算,這樣計(jì)算的時(shí)候很方便,而且可以相對(duì)于瀏覽器的設(shè)置來改變文字大小。

那為什么要用百分比呢?因?yàn)榭紤]到輔助功能和瀏覽器設(shè)置。對(duì)于部分用戶,可能會(huì)在手機(jī)或?yàn)g覽器的設(shè)置中增大手機(jī)字號(hào),這意味著對(duì)方平時(shí)看字是很費(fèi)力的,所以他才要放大。那把html的字號(hào)設(shè)置成百分比就很貼心了,會(huì)隨著手機(jī)設(shè)置改變頁面的字號(hào)。

在手機(jī)上設(shè)置默認(rèn)字號(hào)是很常見的現(xiàn)象,所以如果是一個(gè)充滿人道主義的排版,我覺得用百分比是非常高尚的。它不僅從視覺角度去考慮美,更加做到了“用戶至上”這四個(gè)字。

好,回到現(xiàn)實(shí)環(huán)境。只有國(guó)外那些對(duì)Accessibility要求比較高的國(guó)家,才會(huì)真正去落實(shí)這些。但國(guó)內(nèi)的話,老實(shí)說,更注重外觀的美。從來沒有哪家互聯(lián)網(wǎng)公司的頁面會(huì)去兼容Screen Reader,也很少做Keyboard Shortcut。

扯遠(yuǎn)了,就算你看到用62.5%的情況,有些間距也是不合理的,都做的不太好,特別是把文案做到圖片上的,對(duì)字號(hào)根本不敏感。如果出發(fā)點(diǎn)不是為了用戶的視覺接受能力,那就別用62.5%;如果想做,就把縮放考慮到位了,別做半吊子。

另外,針對(duì)本小節(jié)開頭用16px的情況,這里再給大家提供一招(我調(diào)研了一下目前沒人這么用,也是靈光一現(xiàn)才想到的)。

用Media Query的缺點(diǎn)是什么?它是分段函數(shù),對(duì)于寬度在[320, 360)區(qū)間內(nèi)的屏幕,會(huì)適用同一套方案。最完美的應(yīng)該是線性函數(shù),怎么做?很簡(jiǎn)單,用vw即可。

html {
    font-size: 4.266667vw;
}

用1行代碼代替之前6個(gè)冗長(zhǎng)的Media Query,還不錯(cuò)吧。

如何提高rem的可讀性

我們來談最后一個(gè)話題。

當(dāng)你知道htmlfont-size怎么設(shè)置后,肯定想問,難道我每次寫代碼時(shí),還得做個(gè)除法,把rem的值計(jì)算出來嗎?

我相信稍微“現(xiàn)代”一點(diǎn)的開發(fā)者,都會(huì)用到CSS預(yù)處理?;谶@個(gè)工具,事情就很好辦了,以LESS為例,兩步操作如下:

// 1. 按iPhone 6的視覺稿,基準(zhǔn)字號(hào)為16px,因此可以設(shè)置一個(gè)LESS變量。
@px: 16rem;

// 2. 通過LESS內(nèi)置的除法自動(dòng)運(yùn)算。比如用到16px的字號(hào)時(shí),寫成16/@px即可,最后會(huì)計(jì)算成1rem。
.example {
    font-size: 16/@px;
    margin: 20/@px 0;
    padding: 20/@px 10/@px;
}
小結(jié)

本文給大家介紹了rem的適配方式,如何設(shè)置htmlfont-size,如何更快地書寫rem的值。

本文沒有任何“PHP是最好的語言”這種類似的導(dǎo)向,都是根據(jù)自己的經(jīng)驗(yàn)和觀察所得出的結(jié)論,若有不對(duì)請(qǐng)指正。

頁面適配是很精細(xì)的工作,可能你已經(jīng)有了一套非常熟練的開發(fā)方式,那保持下去即可。如果沒有,不妨參考一下這篇文章。

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

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

相關(guān)文章

  • 對(duì)于頁面適配,應(yīng)該使用px還是rem

    摘要:第一種情況也不討論了,通過斷點(diǎn)適配后,其實(shí)你處理的還是第二種情況。至于移動(dòng)端,支持情況不錯(cuò),可以在生產(chǎn)環(huán)境使用。 css中的單位很多,%、px、em、rem,以及比較新的vw、vh等。每個(gè)單位都有特定的用途,比如當(dāng)需要設(shè)置一個(gè)矩形的寬高比為16:9,并且隨屏幕寬度自適應(yīng)時(shí),除了用%,其他單位是很難做到的。所以不存在說某個(gè)單位是錯(cuò)誤的,某個(gè)單位是最好的這種說法。 那本文說的頁面適配,指的...

    dkzwm 評(píng)論0 收藏0
  • 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頁面的終端適配和再...

    wangbinke 評(píng)論0 收藏0
  • 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
  • 移動(dòng)端的3種適配方法

    摘要:做移動(dòng)端頁面以來,經(jīng)常會(huì)聽說移動(dòng)端的適配這個(gè)問題,但是并沒有認(rèn)真分析過是如何適配各種機(jī)型的。目前公司用的是手淘的進(jìn)行頁面適配的。手淘那個(gè)還有的地方看不懂,還是自己太了,但是看不懂車不影響老司機(jī)開車。 做移動(dòng)端頁面以來,經(jīng)常會(huì)聽說移動(dòng)端的適配這個(gè)問題,但是并沒有認(rèn)真分析過是如何適配各種機(jī)型的。目前公司用的是手淘的flexible.js進(jìn)行頁面適配的。適配的根本原理其實(shí)就是將設(shè)計(jì)稿按一定的...

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

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

0條評(píng)論

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