国产性猛交xx乱_性色国产成人久久久精品_亚洲成年人av_亚洲av片不卡无码久久_日本精品一二三_久久免费精品国产_欧美成人精品一区二区综合免费_无码人妻丰满熟妇区毛片蜜桃精品_四虎永久免费影院_国产一区二区三区四区在线

了解并使用CSS中的rem單位

 

如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點這里

今天我們深度了解一下 rem 單位,這個單位目前已經(jīng)得到了優(yōu)秀瀏覽器的支持,并且有一些兼容方案來幫助你在低版本的 IE 瀏覽器中的使用它。

什么是 rem

可能在你使用收音機或者用其他音樂播放器之前,就已經(jīng)聽過“R.E.M.”這個詞了。在這個樂隊眼中,這個詞是“淺睡眠時眼球的快速轉(zhuǎn)動”的縮寫,而在 css 中,rem 代表著“以根元素為參照物的 em 單位“。他不會讓你拋棄你的宗教信仰也不會讓你相信那個遠在月球的人,但是它可以幫助你實現(xiàn)一個和諧、平穩(wěn)的設(shè)計。

根據(jù) W3C 規(guī)范中對 1rem 的定義:

1rem 與等于根元素 font-size 的計算值。當明確規(guī)定根元素的 font-size 時,rem 單位以該屬性的初始值作參照。

這就意味著 1rem 等于 html 元素的字體大小(大部分瀏覽器根元素的字體大小為16px)

Rem 單位 vs Em 單位

使用 em 單位最主要的問題是他們與用戶元素相關(guān)聯(lián)。在這種情況下,這些元素可以相互嵌套并且造成意想不到的結(jié)果。我們來思考下面一個例子,在根元素的文字大小為默認值16px 的情況下,我們想要所有列表的字體大小均為 12px :

html { font-size: 100%;
} ul { font-size: 0.75em;
}

假如有一個列表是嵌套在另一個列表下,那么內(nèi)列表的字體大小將會是外列表字體大小的 75%(也就是 9px ),我們?nèi)匀豢梢酝ㄟ^幾行代碼來解決這個問題:

ul ul { font-size: 1em;
}

這樣就可以解決這個問題,然而我么仍需要特別關(guān)注那些嵌套特別深的元素。

當使用 rem 單位后,事情就變得簡單了:

html { font-size: 100%;
} ul { font-size: 0.75rem;
}

當所有尺寸都以根元素的文字大小作為參照后,就不再需要為嵌套的元素單獨定義樣式了。

使用 rem 單位定義文字大小

Jonathan Snook 是第一批使用 rem 單位來定義文字大小的開發(fā)者,早在 2011 年 5 月,他就發(fā)表了題為《使用 rem 來定義文字大小》 的文章。和大多數(shù) CSS 開發(fā)者一樣,他必須去解決在 em 單位在復(fù)雜的布局上的一系列問題。

在那時候,老版本的 IE 依然有很大的市場份額,并且他們不可以縮放由 px 來定義的文本。然而,就像我們之前看到的那樣,在使用 em 單位的情況下,很容易忘記元素之前的嵌套關(guān)系,并且得到一個意想不到的結(jié)果。

使用 rem 單位來定義文字的大小最大的問題在于這些值有點難以使用。讓我們來看一個例子,假設(shè)根元素的文字大小是 16px,我們常用的文字大小轉(zhuǎn)換為 rem 值如下:

  • 10px = 0.625rem
  • 12px = 0.75rem
  • 14px = 0.875rem
  • 16px = 1rem (base)
  • 18px = 1.125rem
  • 20px = 1.25rem
  • 24px = 1.5rem
  • 30px = 1.875rem
  • 32px = 2rem

正如我們看到的那樣,這些值在計算起來非常不方便。因此,Snook 使用一個叫 62.5 的方式來解決這個問題。然而這并不是一個創(chuàng)新,因為它早已在 em 單位中運用了:

body { font-size:62.5%; } /* =10px */ h1 { font-size: 2.4em; } /* =24px */ p { font-size: 1.4em; } /* =14px */ li { font-size: 1.4em; } /* =14px? */

因為 rem 單位與根元素相關(guān)聯(lián),Snook 改進后的方案變?yōu)榱耍?

html { font-size: 62.5%; } /* =10px */ body { font-size: 1.4rem; } /* =14px */ h1 { font-size: 2.4rem; } /* =24px */

有一點值得考慮的是有一些瀏覽器不支持 rem 單位。因此上面的代碼可以按照以下方式來改寫:

html { font-size: 62.5%;
} body { font-size: 14px; font-size: 1.4rem;
} h1 { font-size: 24px; font-size: 2.4rem;
}

盡管這個解決方案看起來是最好的解決方案,但還是有人不建議使用這種方式。Harry Roberts 寫了一篇文章,里面記錄了他在實際使用 rem 單位過程中的一些感受。從他的觀點來看,雖然 62.5% 這種解決方案使得計算變得簡單(因為字體大小以 px 為單位時的值正好是以 rem 為單位的 10 倍),但是他迫使開發(fā)者重寫他們網(wǎng)站中的所有文字大小。

Chris Coyier 在 CSS-Tricks 提出了第三種解決方案。他的解決方式充分利用了到目前為止我們遇到的三種單位。根元素的長度單位依舊采用 px ,模塊用 rem 單位,模塊內(nèi)的元素使用 em 單位。這種方式可以很容易的操作根元素的大小、縮放模塊,模塊內(nèi)內(nèi)容的大小以模塊自身文字大小來進行縮放。Louis Lazaris 隨后在 CSS 中 em 單位的強大之處 提出了他的觀點。

在下面的例子中你可以看出 Chris 的解決方案是怎么工作的:

代碼可以看 SitePoint(@SitePoint) 在 CodePen 寫的 《在 CSS 中使用 em 和 rem 單位的方式》。

正如你看到的那樣,沒有利用新技術(shù)來解決這個問題。可能一些組合方式僅僅被開發(fā)者的想象力所限制。

在媒體查詢中使用 rem 單位

在媒體查詢中利用 em 和 rem 單位,與“行的最佳長度”的概念密切向關(guān),并能給用戶帶來流暢的閱讀體驗。在 2014 年 9 月,Smashing Magazine 在 web typography 發(fā)表了一篇名叫 尺寸那些事: 在 web 響應(yīng)式設(shè)計中掌握文字大小與行寬度的平衡的文章。最有意思的是,文章給出了行的最佳寬度度,45 到 85 個字符(包括空格和標點符號),65 是最理想的行寬值。

粗略的估計一個字節(jié)大小就是 1rem,利用這個方法我們就可以用一種移動優(yōu)先的方式控制內(nèi)容的單行文本流:

.container { width: 100%;
}

@media (min-width: 85rem) { .container { width: 65rem;
  }
}

然而在媒體查詢中使用 em 和 rem 單位作為媒體查詢的條件時有一個有意思的細節(jié):1 rem,1em 還有瀏覽器默認文字大小這三值表示這同一個值。這樣做的原因可以在媒體查詢規(guī)范得到解釋(特別強調(diào)):

詢中相對單位都是以一個初始值作為基準,這就意味著這些單位永遠不會基于聲明的結(jié)果。例如:在 HTML 中,em 單位與用戶瀏覽器或者用戶偏好設(shè)置中設(shè)置的初始文字大小有關(guān),而不是頁面上的樣式中定義的文字大小。

讓我們看一個關(guān)于這個特性的一個小例子:

在 CodePen 上看一個關(guān)于媒體查詢的 demo

首先,在我們的 HTML 文檔中,有一個元素將會展現(xiàn)視口的寬度:

`Document width: <span></span>px`

接下來是兩條媒體查詢語句,一條是使用 rem 單位,另一條使用 em 單位(這里為了簡便,使用了 Sass)

html {
  font-size: 62.5%; /* 62.5% of 16px = 10px */ @media (min-width: 20rem) { /* 20*16px = 320px */ background-color: lemonchiffon;
    font-size: 200%; /* 200% of 16px = 32px */ }

  @media (min-width: 30em) { /* 30*16px = 480px */ background-color: lightblue;
    font-size: 300%; /* 300% of 16px = 48px */(譯:原文是48px)
  }
}

最后,我們使用一點 jQuery 在頁面上顯示視口的寬度,并且在窗口縮放的時候更新這個值:

$('span').text($(window).width());

$(window).on('resize', function(e) {
  $('span').text($(window).width());
});

在開頭,我們使用了 62.5% 這個方法來說明,修改根元素字體大小不會對媒體查詢產(chǎn)生任何影響。當我們更改窗口的寬度時,我們可以看到在 320 px 時,第一條媒體查詢開始起作用,到480px第二條媒體查詢開始起作用。任何一條在媒體查詢中對文字大小聲明的改變都沒有起作用。唯一一個可以改變媒體查詢中寬度的是在瀏覽器里更改默認文字大小。

因為這個原因,在媒體查詢語句中使用 em 單位還是 rem 單位已經(jīng)不那么重要了。事實上,無論是Foundation v5還是最近剛發(fā)布的Bootstrap v4 alpha都在他們的媒體查詢中使用了 em 單位。

使用 rem 單位來縮放文檔

我們能發(fā)現(xiàn)的第三種使用 rem 單位的方式是去構(gòu)建可縮放組件。使用 rem 來定義元素的寬度,外邊距和內(nèi)邊距 通過使用根元素的字體大小作為一個接口使元素縮放一致變?yōu)榱丝赡堋?我們可以通過下面兩個例子來看這是怎么起作用的。

使用 rem 來縮放文檔實例一

在這個例子里,我們通過媒體查詢中更改根元素的文字大小。就像上一個章節(jié)所講,這樣做的目的是為用戶定制不同設(shè)備下的不同閱讀體驗。通過 rem 單位來表示寬度,外邊距,內(nèi)邊距,這樣所有元素就會基于用戶的設(shè)備大小縮放。

讓我們看另一個例子:

代碼可以看 SitePoint(@SitePoint) 在 CodePen 寫的 《使用 rem 動態(tài)縮放模塊》

在第二個例子中,我們使用 JavaScript 來做同樣的操作。這次用戶根據(jù)自己的需要手動控制界面的大小。我們可以使用多種方式(可以使用數(shù)據(jù)庫,cookie 還有本地存儲)來存儲用戶數(shù)據(jù),這樣就可以給用戶搭建一個基于用戶偏好的個性化系統(tǒng)。

總結(jié)

在這里總結(jié)一下到目前為止我們對 CSS 中 rem 單位的認識。很顯然,在項目中使用 rem 有許多優(yōu)點,比如:響應(yīng)式,可縮放,增加閱讀體驗,增加自定義元素的靈活性。rem 雖然不是一個通用的解決方案,但是通過謹慎的使用,它還是可以解決困擾開發(fā)者多年的問題。 我們每個人都可以去挖掘 rem 的所有潛能。從你的編輯器開始吧,實驗并向我們分享您的成果。

 

 藍藍設(shè)計m.wowo44.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計BS界面設(shè)計  cs界面設(shè)計  ipad界面設(shè)計  包裝設(shè)計  圖標定制  用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù) 

 

日歷

鏈接

個人資料

藍藍設(shè)計的小編 http://m.wowo44.com

存檔

国产性猛交xx乱_性色国产成人久久久精品_亚洲成年人av_亚洲av片不卡无码久久_日本精品一二三_久久免费精品国产_欧美成人精品一区二区综合免费_无码人妻丰满熟妇区毛片蜜桃精品_四虎永久免费影院_国产一区二区三区四区在线
欧美在线小视频| 亚洲一区二区三区四区五区黄 | ass精品国模裸体欣赏pics| 亚洲精品乱码久久久久久蜜桃图片| 国产美女福利视频| 欧美国产日韩精品免费观看| 激情综合网最新| 免费看91的网站| 久久久影视传媒| 韩国理伦片一区二区三区在线播放| 无套内谢大学处破女www小说| 欧美一区二区在线播放| 日本网站在线观看一区二区三区| 日本一级片在线播放| 欧美人牲a欧美精品| 亚洲午夜国产一区99re久久| 日本黄色大片在线观看| 欧美日韩国产a| 日韩高清在线观看| 精品人妻一区二区三区视频| 国产在线播放一区三区四| 白白色免费视频| 国产日韩欧美制服另类| 国产91清纯白嫩初高中在线观看| 丝袜美腿小色网| 亚洲人成网站色在线观看| 97se亚洲国产综合自在线观| 精品视频在线视频| 日韩精品电影一区亚洲| www.中文字幕av | 黄色在线免费播放| 欧美一区二区啪啪| 精品亚洲国内自在自线福利| 久久久久无码精品国产sm果冻| 国产亚洲短视频| 99久久伊人网影院| 欧美久久久久久久久中文字幕| 天使萌一区二区三区免费观看| 久久久无码人妻精品一区| 久久这里只有精品6| 成人在线视频一区二区| 欧美亚洲日本一区| 热久久一区二区| 国产白丝一区二区三区| 亚洲欧美日韩久久精品| 午夜男人的天堂| 国产亚洲欧洲一区高清在线观看| 成人av第一页| 91精品国产色综合久久| 国产一区二区视频在线| 欧美自拍丝袜亚洲| 美女免费视频一区| 国产男女猛烈无遮挡在线喷水| 有码一区二区三区| 国产精品无码久久久久一区二区| 国产精品免费视频观看| 成年人小视频在线观看| 久久久亚洲高清| 人妻少妇偷人精品久久久任期| 欧美一二三四区在线| 国产成人在线视频免费播放| 欧美撒尿777hd撒尿| 精品一区二区三区在线观看国产| 色综合久久综合网| 日韩精品最新网址| 国产v日产∨综合v精品视频| 欧美日韩和欧美的一区二区| 国产在线播放一区三区四| 欧美丝袜第三区| 狠狠色狠狠色合久久伊人| 在线观看一区日韩| 久久69国产一区二区蜜臀| 欧洲视频一区二区| 韩国成人在线视频| 欧美人成免费网站| 国产91高潮流白浆在线麻豆| 欧美一区在线视频| 99久久精品免费观看| 欧美精品一区二区三区蜜桃 | 国产欧美日韩另类一区| 免费人成精品欧美精品| 在线区一区二视频| 精品一区二区三区不卡| 欧美三级视频在线观看| 国产成人免费在线观看不卡| 91精品国产手机| 99re这里只有精品6| 国产亚洲欧美日韩日本| 性久久久久久久久久久| 中文字幕综合网| 日本午夜精品视频| 日本午夜精品一区二区三区电影| 欧美中文字幕一区二区三区| 国产精品亚洲成人| 欧美电视剧免费全集观看| gogo亚洲国模私拍人体| 国产精品乱码人人做人人爱| 51妺嘿嘿午夜福利| 日韩国产欧美一区二区三区| 国产一区二区0| 91精品国产欧美一区二区18| 99国产精品久| 中文字幕在线观看不卡视频| 国产精品久久久视频| 男女男精品网站| 51精品秘密在线观看| 亚洲区 欧美区| 亚洲欧美电影院| 欧美黑人猛猛猛| 国产成人av电影在线观看| 久久亚洲综合av| 一卡二卡三卡四卡| 日韩激情一区二区| 91精品在线一区二区| 亚洲黄色小说在线观看| 亚洲黄色在线视频| 在线视频亚洲一区| 91网址在线看| 亚洲欧美在线高清| 91九色丨porny丨极品女神| 国产91丝袜在线播放九色| 欧美国产日韩精品免费观看| 五月天婷婷丁香网| 国产乱人伦偷精品视频免下载| 久久亚洲二区三区| 国产成人免费观看网站| 国内外成人在线视频| 久久久久久久久99精品| 91精品国自产在线| 国产高清不卡二三区| 亚洲国产精品v| 天天色影综合网| eeuss国产一区二区三区| 一区在线观看免费| 在线视频欧美精品| 精品人妻无码中文字幕18禁| 亚洲午夜久久久久久久久久久| 欧美日韩高清不卡| 奇米777第四色| 蜜臀久久久99精品久久久久久| 日韩精品一区二区三区中文精品| 国产精品无码永久免费不卡| 久久国产夜色精品鲁鲁99| 久久久久久日产精品| 99自拍视频在线| 99在线热播精品免费| 亚洲主播在线播放| 欧美一级理论片| 舐め犯し波多野结衣在线观看| 国产真实乱对白精彩久久| 日本一区二区成人| 色婷婷精品久久二区二区蜜臂av| 性生活在线视频| 婷婷久久综合九色综合绿巨人| 精品国产伦理网| 我要看黄色一级片| 麻豆免费在线观看视频| 日韩高清在线电影| 日本一区二区视频在线| 在线看日韩精品电影| 日本三级日本三级日本三级极| 蜜臀99久久精品久久久久久软件| 久久精品欧美一区二区三区不卡 | 中文字幕 亚洲一区| 久久精品国产精品亚洲综合| 国产嫩草影院久久久久| 在线亚洲免费视频| 日韩在线免费观看av| 国产成人精品aa毛片| 亚洲综合视频网| 日韩免费视频一区二区| 黑人狂躁日本娇小| 日韩少妇一区二区| 国产毛片精品视频| 亚洲一区中文日韩| 精品国产乱码91久久久久久网站| 一区二区国产精品精华液| 国产一级免费片| 国产剧情一区二区三区| 一区二区三区**美女毛片| 精品国产乱码久久久久久牛牛| 1024手机在线视频| 久久久久久久久免费看无码| 欧美精品一级二级三级| 免费黄色在线网址| 午夜视频在线免费看| 国产一区二区三区高清播放| 一区二区日韩av| 国产午夜精品福利| 欧美日韩国产一级片| 欧美色图17p| 欧美一级片黄色| 成人免费看黄yyy456| 日韩成人一区二区| 亚洲日本电影在线| 久久香蕉国产线看观看99| 欧美日韩综合在线| 午夜精品福利在线视频| 野外性满足hd| 肉丝美足丝袜一区二区三区四|