前言:入職公司不知不覺(jué)已經(jīng)兩個(gè)星期了,在這里我要吐槽一下,看過(guò)我的文章的人都知道我是Android,Java方向的,至于PHP也是以后配合Java方向發(fā)展而自學(xué)了點(diǎn)。在我現(xiàn)在這家公司面試的時(shí)候我面的是Android開(kāi)發(fā)的,老板不懂技術(shù),要求做微商城,我以為是做商城版的app結(jié)果不是,而是移動(dòng)端web,可能這就是緣分吧,是這公司的人事小姐姐主動(dòng)打電話叫我來(lái)面的試,結(jié)束了我正在找實(shí)習(xí)工作的痛苦。入職時(shí),由于做后臺(tái)開(kāi)發(fā)的人太多了,我就被分配到了前端,我的實(shí)習(xí)生涯正式開(kāi)始!前端對(duì)于我來(lái)說(shuō)我就是個(gè)小白,在此遇到的一些問(wèn)題對(duì)于小白來(lái)說(shuō)是要注意的!
好了我們進(jìn)入主題,其實(shí)做移動(dòng)web最重要的是做什么呢?(這里不談動(dòng)態(tài)頁(yè)面數(shù)據(jù)交互)那就是要做自適應(yīng),那要怎么做自適應(yīng)呢?首先我們就要了解px、em、rem之間的區(qū)別!
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í)元素的字體大小。
注意:任意瀏覽器的默認(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作為單位就行了。
所以我們?cè)趯?xiě)CSS的時(shí)候,需要注意兩點(diǎn):
(1) body選擇器中聲明Font-size=62.5%
(2)將你的原來(lái)的px數(shù)值除以10,然后換上em作為單位
(3) 重新計(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)單,就是多寫(xiě)一個(gè)絕對(duì)單位的聲明。這些瀏覽器會(huì)忽略用rem設(shè)定的字體大小。下面就是一個(gè)例子:
p {font-size:14px; font-size:.875rem;}
px 與 em與 rem 的選擇?
介紹玩上面的特點(diǎn)了那么我們?cè)撊绾芜x擇呢?
我們總結(jié)一下:
px實(shí)際上就是像素,用PX設(shè)置字體大小時(shí),比較穩(wěn)定和精確。但是px不支持用戶進(jìn)行瀏覽器縮放或者不同移動(dòng)端的兼容,因?yàn)橄袼厥枪潭ǖ?,屏幕大小是變化的。由此引入了em和rem。
em是根據(jù)父元素來(lái)對(duì)應(yīng)大小,是一種相對(duì)值,并不是絕對(duì)值,em值 = 1/父元素的font-size*需要轉(zhuǎn)換的像素值。進(jìn)行任何元素設(shè)置,都有可能需要知道他父元素的大小,這很不方便所以又有了rem。
rem是根據(jù)根元素html的font-size來(lái)對(duì)應(yīng)大小,1rem = 100px,可以在根元素html中寫(xiě)固定像素也可以寫(xiě)百分比,然后在具體的標(biāo)簽上設(shè)置rem
回到我們的問(wèn)題,我們現(xiàn)在是要做自適應(yīng)當(dāng)然首選em或rem,對(duì)于只需要適配少部分手機(jī)設(shè)備,且分辨率對(duì)頁(yè)面影響不大的,使用px即可 。對(duì)于需要適配各種移動(dòng)設(shè)備使用rem,例如只需要適配iPhone和iPad等分辨率差別比較挺大的設(shè)備。說(shuō)到這里相信小伙伴們都知道該選神馬了。
有興趣可以看看em與 rem 的使用詳解這篇文章:http://caibaojian.com/rem-vs-em.html
移動(dòng)web前端布局問(wèn)題
了解完上面的內(nèi)容后接下來(lái)就是在布局中的問(wèn)題了,上面都是為了這里的鋪墊,這里我就不寫(xiě)了請(qǐng)看大神的文章https://blog.csdn.net/u010852544/article/details/53538362
最后在此,我要感謝一個(gè)人,一個(gè)陌生人,他是我在一個(gè)前端群里人認(rèn)識(shí)的人,他q名叫胡漢三,我叫他三哥,感謝他總是很熱心的幫我解決問(wèn)題,就像我Android的師傅一樣,不僅僅交我技術(shù)還交會(huì)了我很道理。