95%的中國網站需要重寫CSS_經驗交流

來源:互聯網
上載者:User
很長一段時間,我都使用12px作為網站的主要字型大小。10px太小, 眼睛很容易疲勞,14px雖容易看清,卻破壞頁面的美感。唯獨12px在審美和視力方面都恰到好處。

誰對我的網站字型大小有意見?
我老爸,他是第一個向我反映看不清我的網站文字的人。這使我意識到12px,其實只是讓我覺得很不錯而已,而對於那些視力下降明顯的中年以上的人來講,幾乎等於10px對於我的感覺。
於是我告訴他,在“查看”裡調整“文字大小”就可以了。但是卻發現這是徒勞的。在Firefox能輕易調整的字型大小,怎麼在IE就變得如此”堅不可調“?

問題出在哪
我又試著開啟中國的三大門戶—新浪,網易,搜狐。它們的字型無一例外的在IE裡失去可調性。看來這不是我網站專屬的毛病。再看看MSN,Google,A list apart,華盛頓郵報,在IE裡卻是可調的。難道IE在字型調整上也搞歧視不成?
困擾我的問題直到看到這篇大作:How to size text using ems,才得到徹底的解決。
關鍵點
1. IE無法調整那些使用px作為單位的字型大小;
2. 國外的大部分網站能夠調整的原因在於其使用了em作為字型單位;
3. Firefox能夠調整px和em,但是96%以上的中國網民使用IE瀏覽器(或核心)。這意味這中國網站的字型大小可以被認為不可調。

95%的中國網站需要重寫CSS
在我所觀察的中國網站中,包括三大門戶,以及“引領”中國網站設計潮流的藍色理想,ChinaUI等都是使用了px作為字型單位。只有百度好歹做了個可調的表率。
而在大洋彼岸,幾乎所有的主流網站都使用em作為字型單位,也就是可調的。
沒錯,px比em更加容易使用,我也敢打賭大部分讀者不知道em為何物或者它相當於多少px。
國外人士如此重視網站易用性(Accessibility),不僅因為其根生蒂固的人文精神,直接原因可能是因為有一部法律來約束他們—例如美國的Section 508,強制網站達到一定的易用性。所以沒有哪個主流網站願意被那些視力下降或是殘缺的人告上法庭。
注: 在中國, 可能把微軟告上法庭來的更簡單點,為什麼IE對於px那麼死板。

如何重寫你的網站CSS
Jorux.com作為一個對視力下降人士負責任的網站,已經重寫了CSS的Font-size部分。在這裡,Jorux和各個有人文精神的網站主討論如何用em重寫Font-szie的問題。

em vs. px

em是何物?
em指字型高,任意瀏覽器的預設字型高都是16px。所以未經調整的瀏覽器都符合: 1em=16px。那麼12px=0.75em, 10px=0.625em。為了簡化font-size的換算,需要在css中的body選取器中聲明Font-size=62.5%,這就使em值變為16px*62.5%=10px, 這樣12px=1.2em, 10px=1em, 也就是說只需要將你的原來的px數值除以10,然後換上em作為單位就行了。em有如下特點:
1. em的值並不是固定的;
2. em會繼承父級元素的字型大小。

重寫步驟:
1. body選取器中聲明Font-size=62.5%;
2. 將你的原來的px數值除以10,然後換上em作為單位;
簡單吧,如果只需要以上兩步就能解決問題的話,可能就沒人用px了。經過以上兩步,你會發現你的網站字型大得出乎想象。因為em的值不固定,又會繼承父級元素的大小,你可能會在content這個div裡把字型大小設為1.2em, 也就是12px。然後你又把選取器p的字型大小也設為1.2em,但如果p屬於content的子級的話,p的字型大小就不是12px,而是1.2em=1.2 * 12px=14.4px。這是因為content的字型大小被設為1.2em,這個em值繼承其父級元素body的大小,也就是16px * 62.5% * 1.2=12px, 而p作為其子級,em則繼承content的字型高,也就是12px。所以p的1.2em就不再是12px,而是14.4px。
3. 重新計算那些被放大的字型的em數值。避免字型大小的重複聲明,也就是避免以上提到的1.2 * 1.2= 1.44的現象。比如說你在#content中聲明了字型大小為1.2em,那麼在聲明p的字型大小時就只能是1em,而不是1.2em, 因為此em非彼em,它因繼承#content的字型高而變為了1em=12px。

詭異的12px漢字(原因待查)
本人在完成em轉換時還發現了一個詭異的現象,就是由以上方法得到的12px(1.2em)大小的漢字在IE中並不等於直接用12px定義的字型大小,而是稍大一點。這個問題我已經解決,你只需在body選取器中把62.5%換成63%就能正常顯示了。原因可能是IE處理漢字時,對於浮點的取值精確度有限。閱讀本篇的讀者還有其他解釋嗎?
本現象只發生在12px的漢字,英文不存在此現象。你可以在這裡下載到此表現此現象的檔案。下載後請讀者用IE開啟sample.htm, 可以看到第一段文字明顯長於第二段。然後你可以用編輯器開啟style.css,看看究竟發生了什麼。解決方案就是把style.css中的62.5%換為63%。示範連結

還可以做哪些改進

為什麼還需改進:
1. 你的網站css過於複雜,以至於不知道元素的從屬關係,很難重寫css;
2. 絕大部分人看了本文之後仍然不會重寫css;
3. 很大部分人不知道瀏覽器可以調整頁面的字型大小。

所以你需要一個諸如本站資訊框中的字型大小調整控制項。
相信本站讀者的英語能力,這裡就不再羅嗦了,請參看:The Text Changer

Important reference:
1. How to size text using ems
2. The Text Changer

備忘:
1. 自網站Reboot以來,老爸又反映我整天在”屬性一”"屬性二”的,看不大明白,已經拒絕訪問Jorux.com了;
2. 讀者對如何用em重寫css,或是對字型大小調整控制項有任何疑問,請留言;
3. 本站在加強易用性上做了如下改進:a. 用em重寫了css; b. 去除了51.la和文本廣告代碼,提高了網頁載入速度; c. 增加了字型大小調整控制項;
4. 重新整理”Other Blogger”連結,請發現被摘掉連結的網站自行摘除鏈向本站的連結,本站停止交換友情連結。尚保留的網站有如下特點:a. 非日記式部落格;b. 內容優秀;c. 原創為主;
5. 本站常規在周一發表post,間隔為一到兩周,感謝讀者對本站的關注, 以後除星期一以外,您都不需更新本站Feed了。

  • 相關文章

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.