國(guó)內(nèi)的設(shè)計(jì)師大都喜歡用px,而國(guó)外的網(wǎng)站大都喜歡用em和rem团南,那么三者有什么區(qū)別噪沙,又各自有什么優(yōu)劣呢炼彪?
PX特點(diǎn)
- IE無(wú)法調(diào)整那些使用px作為單位的字體大型赂;
- 國(guó)外的大部分網(wǎng)站能夠調(diào)整的原因在于其使用了em或rem作為字體單位辐马;
- Firefox能夠調(diào)整px和em拷橘,rem,但是96%以上的中國(guó)網(wǎng)民使用IE瀏覽器(或內(nèi)核)喜爷。
px像素(Pixel)冗疮。相對(duì)長(zhǎng)度單位。像素px是相對(duì)于顯示器屏幕分辨率而言的檩帐。(引自CSS2.0手冊(cè))
em是相對(duì)長(zhǎng)度單位术幔。相對(duì)于當(dāng)前對(duì)象內(nèi)文本的字體尺寸。如當(dāng)前對(duì)行內(nèi)文本的字體尺寸未被人為設(shè)置湃密,則相對(duì)于瀏覽器的默認(rèn)字體尺寸诅挑。(引自CSS2.0手冊(cè))
任意瀏覽器的默認(rèn)字體高都是16px。所有未經(jīng)調(diào)整的瀏覽器都符合: 1em=16px泛源。那么12px=0.75em,10px=0.625em拔妥。為了簡(jiǎn)化font-size的換算,需要在css中的body選擇器中聲明Font-size=62.5%达箍,這就使em值變?yōu)?16px*62.5%=10px, 這樣12px=1.2em, 10px=1em, 也就是說(shuō)只需要將你的原來(lái)的px數(shù)值除以10没龙,然后換上em作為單位就行了。
EM特點(diǎn)
- em的值并不是固定的缎玫;
- em會(huì)繼承父級(jí)元素的字體大小硬纤。
所以我們?cè)趯慍SS的時(shí)候,需要注意兩點(diǎn):
- body選擇器中聲明Font-size=62.5%赃磨;
- 將你的原來(lái)的px數(shù)值除以10筝家,然后換上em作為單位;
- 重新計(jì)算那些被放大的字體的em數(shù)值煞躬。避免字體大小的重復(fù)聲明肛鹏。
也就是避免1.2 * 1.2= 1.44的現(xiàn)象逸邦。比如說(shuō)你在#content中聲明了字體大小為1.2em,那么在聲明p的字體大小時(shí)就只能是1em在扰,而不是1.2em, 因?yàn)榇薳m非彼em缕减,它因繼承#content的字體高而變?yōu)榱?em=12px。
rem特點(diǎn)
rem是CSS3新增的一個(gè)相對(duì)單位(root em芒珠,根em)桥狡,這個(gè)單位引起了廣泛關(guān)注。這個(gè)單位與em有什么區(qū)別呢皱卓?區(qū)別在于使用rem為元素設(shè)定字體大小時(shí)裹芝,仍然是相對(duì)大小,但相對(duì)的只是HTML根元素娜汁。這個(gè)單位可謂集相對(duì)大小和絕對(duì)大小的優(yōu)點(diǎn)于一身嫂易,通過(guò)它既可以做到只修改根元素就成比例地調(diào)整所有字體大小,又可以避免字體大小逐層復(fù)合的連鎖反應(yīng)掐禁。目前怜械,除了IE8及更早版本外,所有瀏覽器均已支持rem傅事。對(duì)于不支持它的瀏覽器缕允,應(yīng)對(duì)方法也很簡(jiǎn)單,就是多寫一個(gè)絕對(duì)單位的聲明蹭越。這些瀏覽器會(huì)忽略用rem設(shè)定的字體大小障本。下面就是
一個(gè)例子:
p {font-size:14px; font-size:.875rem;}注意:
選擇使用什么字體單位主要由你的項(xiàng)目來(lái)決定,如果你的用戶群都使用最新版的瀏覽器响鹃,那推薦使用rem驾霜,如果要考慮兼容性,那就使用px,或者兩者同時(shí)使用茴迁。
在這里為大家提供一個(gè)px,em,rem單位轉(zhuǎn)換工具
地址:http://pxtoem.com/
by 專注WEB前端開發(fā) 博客園