CSS樣式表教程之瀏覽器預設樣式

來源:互聯網
上載者:User

不同瀏覽器對於相同元素的預設樣式並不一致,這也是為什麼我們在CSS的最開始要寫 * {padding:0;marging:0};

不過現在說的可不只是這些。基本上,不同核心的兩個瀏覽器在某些元素的表現都會存在差異,比如縮排的大小、字型選擇、字元樣式等。也許一個很漂亮的CSS樣式表在一個瀏覽器上表現良好,在另外一個瀏覽器上即使是沒有CSS Bug的情況也會變得結構混亂起來,我都是瀏覽器預設樣式在作怪。

因此,我們在產生CSS樣式規則的時候,一個必做的步驟就是重設瀏覽器的預設樣式,也就是覆蓋掉瀏覽器的預設樣式。和使用 * {padding:0;margin:0}有所不同,並不是所有的元素都存在padding和margin的差異(元素列表、有序列表在Internet Xplorer和Firefox中的不同是由於它們的縮排採用了margin縮排和padding縮排)。例如下面這段代碼:

<h1> Headlines are very important Elements in XHTML</h1>

這段代碼在Internet Explorer中使用的字型是Times New Roman,而在Firefox和Opera中使用的是系統預設字型。因此我們要為<h1>在CSS中設定一個統一的樣式。

但是,如果我們像使用* {padding:0;margin:0}一樣去使用萬用字元“*”來簡單地設定全域樣式,那麼一個很明顯的問題就會出現,比如像form元素、input元素、textarea等在某些瀏覽器中會忽略對它們的重新設定,更重要的是這將會嚴重破壞這些元素的外觀,所以你又不得不去手動去一一為它們重新設定一個padding值和margin值。所以我們應該放棄簡單地使用“*”,而是為第一個存在表現不一致的元素進行重設,如body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre等等。

同時,元素的預設樣式可能會破壞頁面的外觀。比如<b>元素會把文字加粗,<blockquote>會大段縮排,<em>會使文字傾斜等,如果你想要求頁面文本外觀一致的話,也應該在CSS中把這些元素的外觀進行重設。同時,有時候我們要求這些元素的外觀和父元素一樣,可以直接使用 inherit從父元素繼承即可。

至於哪些元素應該被重設?Yahoo!已經為我們做了比較出的總結。根據雅虎的建議,你需要把這些規則放到一個名為Reset.css的檔案中單獨引用(推薦這種做法):

html{color:#000;background:#FFF;}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,
fieldset,input,textarea,p,blockquote,th,td {
margin:0;
padding:0;
}
table {
border-collapse:collapse;
border-spacing:0;
}
fieldset,img {
border:0;
}
address,caption,cite,code,dfn,em,strong,th,var {
font-style:normal;
font-weight:normal;
}
ol,ul {
list-style:none;
}
caption,th {
text-align:left;
}
h1,h2,h3,h4,h5,h6 {
font-size:100%;
font-weight:normal;
}
q:before,q:after {
content:'';
}
abbr,acronym { border:0;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.