十個非常實用的CSS屬性(IE不支持)
發(fā)布時間:2009-05-22 01:19:57 作者:佚名
我要評論

對IE瀏覽器尤其是IE6的抱怨基本已進(jìn)入麻痹狀態(tài),偶爾甚至產(chǎn)生非常消極的想法: 這個世界只有一個瀏覽器就好了,哪怕這唯一的瀏覽器就是IE6。當(dāng)然,這樣的想法是非常病態(tài)的,馬上打消。本文里面,介紹了10個很實但I(xiàn)E卻不支持的CSS屬性,列出這些屬性并不是為了數(shù)落IE(數(shù)落也沒
對IE瀏覽器尤其是IE6的抱怨基本已進(jìn)入麻痹狀態(tài),偶爾甚至產(chǎn)生非常消極的想法: 這個世界只有一個瀏覽器就好了,哪怕這唯一的瀏覽器就是IE6。當(dāng)然,這樣的想法是非常病態(tài)的,馬上打消。本文里面,介紹了10個很實但I(xiàn)E卻不支持的CSS屬性,列出這些屬性并不是為了數(shù)落IE(數(shù)落也沒用), 而是你了解了哪些CSS屬性是IE不支持的,就更有針對性的去編寫CSS和Hack了。
一、Outline
在調(diào)試CSS問題的時候,我常常在指定元素上添加border來精確的查看該元素會發(fā)生什么并幫助確定問題的來源。這常常是有效的,因為它可以在布 局上給我更加具體的可視性。但是如果是塊級元素,這可能會發(fā)生某些錯誤——在任何塊級元素上添加1px的邊框很可能會影響到布局,它會讓這個元素的寬度額 外增加2px。
outline 屬性是完美的替代者,因為它可以在不影響文檔流的情況下呈現(xiàn)該對象。但是IE6 和IE7 不支持 outline 屬性,所以,它不能在這兩個瀏覽器中用于調(diào)試。
二、Inherit (值)
在CSS開發(fā)中有很多這樣的例子:通過在特定元素上設(shè)置某些樣式來告訴該元素來“繼承”它父級元素的所有已添加的屬性,這樣你就可以避免相當(dāng)多的鍵盤輸入。
這可以通過設(shè)置 inherit 來很容易的實現(xiàn)。這可能很有用。比如,當(dāng)重寫 background 屬性的時候,常常會有很多的文字在該屬性中(色彩、圖片的URL地址、位置等)。所以,與其重新寫這些值,你可能僅僅想要考慮中的元素和其父級元素有相同 的背景屬性,一個 inherit 值就可以搞定一切——這顯然大大的節(jié)省了鍵盤輸入。
不幸的是, inherit 值在IE6和IE7不被支持(除了用于 direction (文字方向) 和 visibility 屬性)。
某人說,代碼就像女人的裙子——越短越好,看來IE會阻礙我們這個愿望的實現(xiàn)。
三、Empty-Cells
該屬性只用于table或者”display”屬性被設(shè)置為”table-cell”的元素。如果你動態(tài)的為一個table添加內(nèi)容,就可能會遇到某個單元格的內(nèi)容為空的情況,然后你又不希望這個空的單元格的邊框、背景色、背景圖片等隱藏掉。
使用”empty-cells: hide”就能解決這個問題,它會將可能出現(xiàn)這種情況的單元格完全隱藏掉。
Internet Explorer 不支持empty-cells屬性。
四、Caption-Side
說到table 的屬性,這個屬性用于聲明顯示在表格的側(cè)欄的表格標(biāo)題。它接受 top 、 bottom 、 left 和 right 四個值。Internet Exporer 不支持這個屬性,table的標(biāo)題在IE6和IE7中將總是出現(xiàn)在表格的頂部。
五、Counter-Increment / Counter-Reset
有序列表(<ol>)非常方便,因為它可以省去你手工添加遞增數(shù)字的麻煩,而且它允許你不用更改數(shù)字就能改變列表的序列。
CSS 擁有 counter-increment 和 counter-reset 屬性,它允許你用來自動生成遞增數(shù)字到幾乎所有的HTML元素上,就像有序列表的效果一樣。
這里有個示例:
h2 {counter-increment: headers;}
h2:before {content: counter(headers) ". ";}
上面的樣式將在所有的 <h2> 標(biāo)簽前面自動添加遞增的數(shù)字,而且允許你在h2標(biāo)簽上實現(xiàn)和li標(biāo)簽同樣的的效果。
但是IE6, IE7 甚至Safari(直到3.x版本)還不支持這些屬性。當(dāng)然,IE6也不支持:before 偽元素。
六、Min-Height
有時,一個網(wǎng)站的設(shè)計或布局結(jié)構(gòu)需要一個有固定高度的內(nèi)容區(qū)域,否則特定的視覺效果就會丟掉。這可能會因為一個漸變背景、一個獨特的下拉列表、 或者可能是因為PS出來的很酷的發(fā)光效果。但是有的時候,頁面中的內(nèi)容會比較多,而頁面卻不能像預(yù)期那樣展開。
這個時候就需要用到 min-height 屬性了,因為它可以告訴瀏覽器在一個特定的塊級元素上渲染最小的高度,不管內(nèi)容的實際高度是否達(dá)到了這個最小高度。然后呢,如果內(nèi)容超出了最小高度,該元素就會適度的擴(kuò)展開。
使用min-height 唯一需要注意到的是它在IE6中不被支持。我們都知道IE6在(緩慢的)退出歷史舞臺,但是有的客戶可能仍然要求他們的網(wǎng)站支持這個該死的瀏覽器。
不過令人高興的是,IE6 渲染 height 的值的方法正好和其它瀏覽器渲染“min-height”的方式一樣,所以你只需要一個針對IE6的hack或獨立的樣式表來為該元素添加特定的 height ,這個問題就解決了。
IE6 同樣無視 min-width 、 max-height 和 max-width , 但是上述方法在這些屬性上也是可行的。
七、:hover
從技術(shù)上來說,:hover只是一個偽類,但是它在IE6中不被支持(IE7和IE8支持)。:hover偽類允許你在元素上添加任何的鼠標(biāo)經(jīng)過樣式。這非常有用,可以避免(至少在某種程度上)使用JavaScript。
但是如果你的網(wǎng)站,需要完全支持IE6,特別是在中國這種IE6一手遮天的情況下,那么你就必須考慮取消使用這個偽類,除非相關(guān)的標(biāo)簽有個”href”屬性,比如<a>標(biāo)簽。而且如果要實現(xiàn)這種效果,可能必須借助于javascript和額外的樣式。
八、Display
Display 通常被設(shè)置為這三個值中的一個: block、inline和 none。“得益于”IE,Display的其它值很少被用到。這些值包括 inline-block、table、inline-table和table-cell等,這些屬性對于解決一些特殊的布局問題時,是很有用的。
所以,盡管IE 確實支持Display的這三個基本屬性,但是它基本上不支持其它屬性。
其實,IE8對display的屬性支持已經(jīng)相當(dāng)完整了。不過,對于inline-block屬性,IE6/7只支持本身為inline的元素。
九. Clip
這是一個在特殊情況下能派上用場的很有趣的CSS屬性。它可能和不可預(yù)知的、動態(tài)生成的內(nèi)容結(jié)合起來。簡單來說,這個屬性允許你在一個特定的元素上 指定隱藏區(qū)域——也可以理解為,在一個絕對定位的元素中,按照一定的設(shè)置來裁剪該元素的顯示區(qū)域,超出該區(qū)域的內(nèi)容會被隱藏掉。語法看起來像這樣的:
div.clipped {
padding: 20px;
width: 400px;
height: 400px;
clip: rect(20px, 300px, 200px, 100px);
position: absolute;
}
修剪只能用于一個絕對定位的元素,而且只用使用矩形區(qū)域。括號內(nèi)的數(shù)字劃出的區(qū)域(200px*180px大小)為可見區(qū)域,該區(qū)域以外的內(nèi)容不可見或者被剪切掉。
技術(shù)上來講, clip 屬性被IE支持,但是只支持無逗號的語法,比如
div.clipped {
padding: 20px;
width: 400px;
height: 400px;
clip: rect(20px 300px 200px 100px);
position: absolute;
}
上面的樣式(rect后面括號里的屬性沒有用逗號隔開)在大多數(shù)瀏覽器下都可運行,但是可能不會通過CSS驗證,因為語句沒有用逗號隔開。
十、:focus
這是另外一個偽類需要在這里被提及的,因為所有的非IE瀏覽器,都支持這個屬性。:focus偽類允許你聲明一個特別的樣式,當(dāng)一個頁面元素成為鍵 盤(鼠標(biāo))焦點的時候,將該樣式動態(tài)的應(yīng)用到該元素上。這在表單元素上非常有用,因為你可以在一個輸入框被選中的時候給它添加一個邊框。
下面的樣式將在輸入框成為鍵盤焦點的時候添加一個紅色的邊框:
input:focus {
border: 1px solid #f00;
}
一、Outline
在調(diào)試CSS問題的時候,我常常在指定元素上添加border來精確的查看該元素會發(fā)生什么并幫助確定問題的來源。這常常是有效的,因為它可以在布 局上給我更加具體的可視性。但是如果是塊級元素,這可能會發(fā)生某些錯誤——在任何塊級元素上添加1px的邊框很可能會影響到布局,它會讓這個元素的寬度額 外增加2px。
outline 屬性是完美的替代者,因為它可以在不影響文檔流的情況下呈現(xiàn)該對象。但是IE6 和IE7 不支持 outline 屬性,所以,它不能在這兩個瀏覽器中用于調(diào)試。
二、Inherit (值)
在CSS開發(fā)中有很多這樣的例子:通過在特定元素上設(shè)置某些樣式來告訴該元素來“繼承”它父級元素的所有已添加的屬性,這樣你就可以避免相當(dāng)多的鍵盤輸入。
這可以通過設(shè)置 inherit 來很容易的實現(xiàn)。這可能很有用。比如,當(dāng)重寫 background 屬性的時候,常常會有很多的文字在該屬性中(色彩、圖片的URL地址、位置等)。所以,與其重新寫這些值,你可能僅僅想要考慮中的元素和其父級元素有相同 的背景屬性,一個 inherit 值就可以搞定一切——這顯然大大的節(jié)省了鍵盤輸入。
不幸的是, inherit 值在IE6和IE7不被支持(除了用于 direction (文字方向) 和 visibility 屬性)。
某人說,代碼就像女人的裙子——越短越好,看來IE會阻礙我們這個愿望的實現(xiàn)。
三、Empty-Cells
該屬性只用于table或者”display”屬性被設(shè)置為”table-cell”的元素。如果你動態(tài)的為一個table添加內(nèi)容,就可能會遇到某個單元格的內(nèi)容為空的情況,然后你又不希望這個空的單元格的邊框、背景色、背景圖片等隱藏掉。
使用”empty-cells: hide”就能解決這個問題,它會將可能出現(xiàn)這種情況的單元格完全隱藏掉。
Internet Explorer 不支持empty-cells屬性。
四、Caption-Side
說到table 的屬性,這個屬性用于聲明顯示在表格的側(cè)欄的表格標(biāo)題。它接受 top 、 bottom 、 left 和 right 四個值。Internet Exporer 不支持這個屬性,table的標(biāo)題在IE6和IE7中將總是出現(xiàn)在表格的頂部。
五、Counter-Increment / Counter-Reset
有序列表(<ol>)非常方便,因為它可以省去你手工添加遞增數(shù)字的麻煩,而且它允許你不用更改數(shù)字就能改變列表的序列。
CSS 擁有 counter-increment 和 counter-reset 屬性,它允許你用來自動生成遞增數(shù)字到幾乎所有的HTML元素上,就像有序列表的效果一樣。
這里有個示例:
h2 {counter-increment: headers;}
h2:before {content: counter(headers) ". ";}
上面的樣式將在所有的 <h2> 標(biāo)簽前面自動添加遞增的數(shù)字,而且允許你在h2標(biāo)簽上實現(xiàn)和li標(biāo)簽同樣的的效果。
但是IE6, IE7 甚至Safari(直到3.x版本)還不支持這些屬性。當(dāng)然,IE6也不支持:before 偽元素。
六、Min-Height
有時,一個網(wǎng)站的設(shè)計或布局結(jié)構(gòu)需要一個有固定高度的內(nèi)容區(qū)域,否則特定的視覺效果就會丟掉。這可能會因為一個漸變背景、一個獨特的下拉列表、 或者可能是因為PS出來的很酷的發(fā)光效果。但是有的時候,頁面中的內(nèi)容會比較多,而頁面卻不能像預(yù)期那樣展開。
這個時候就需要用到 min-height 屬性了,因為它可以告訴瀏覽器在一個特定的塊級元素上渲染最小的高度,不管內(nèi)容的實際高度是否達(dá)到了這個最小高度。然后呢,如果內(nèi)容超出了最小高度,該元素就會適度的擴(kuò)展開。
使用min-height 唯一需要注意到的是它在IE6中不被支持。我們都知道IE6在(緩慢的)退出歷史舞臺,但是有的客戶可能仍然要求他們的網(wǎng)站支持這個該死的瀏覽器。
不過令人高興的是,IE6 渲染 height 的值的方法正好和其它瀏覽器渲染“min-height”的方式一樣,所以你只需要一個針對IE6的hack或獨立的樣式表來為該元素添加特定的 height ,這個問題就解決了。
IE6 同樣無視 min-width 、 max-height 和 max-width , 但是上述方法在這些屬性上也是可行的。
七、:hover
從技術(shù)上來說,:hover只是一個偽類,但是它在IE6中不被支持(IE7和IE8支持)。:hover偽類允許你在元素上添加任何的鼠標(biāo)經(jīng)過樣式。這非常有用,可以避免(至少在某種程度上)使用JavaScript。
但是如果你的網(wǎng)站,需要完全支持IE6,特別是在中國這種IE6一手遮天的情況下,那么你就必須考慮取消使用這個偽類,除非相關(guān)的標(biāo)簽有個”href”屬性,比如<a>標(biāo)簽。而且如果要實現(xiàn)這種效果,可能必須借助于javascript和額外的樣式。
八、Display
Display 通常被設(shè)置為這三個值中的一個: block、inline和 none。“得益于”IE,Display的其它值很少被用到。這些值包括 inline-block、table、inline-table和table-cell等,這些屬性對于解決一些特殊的布局問題時,是很有用的。
所以,盡管IE 確實支持Display的這三個基本屬性,但是它基本上不支持其它屬性。
其實,IE8對display的屬性支持已經(jīng)相當(dāng)完整了。不過,對于inline-block屬性,IE6/7只支持本身為inline的元素。
九. Clip
這是一個在特殊情況下能派上用場的很有趣的CSS屬性。它可能和不可預(yù)知的、動態(tài)生成的內(nèi)容結(jié)合起來。簡單來說,這個屬性允許你在一個特定的元素上 指定隱藏區(qū)域——也可以理解為,在一個絕對定位的元素中,按照一定的設(shè)置來裁剪該元素的顯示區(qū)域,超出該區(qū)域的內(nèi)容會被隱藏掉。語法看起來像這樣的:
div.clipped {
padding: 20px;
width: 400px;
height: 400px;
clip: rect(20px, 300px, 200px, 100px);
position: absolute;
}
修剪只能用于一個絕對定位的元素,而且只用使用矩形區(qū)域。括號內(nèi)的數(shù)字劃出的區(qū)域(200px*180px大小)為可見區(qū)域,該區(qū)域以外的內(nèi)容不可見或者被剪切掉。
技術(shù)上來講, clip 屬性被IE支持,但是只支持無逗號的語法,比如
div.clipped {
padding: 20px;
width: 400px;
height: 400px;
clip: rect(20px 300px 200px 100px);
position: absolute;
}
上面的樣式(rect后面括號里的屬性沒有用逗號隔開)在大多數(shù)瀏覽器下都可運行,但是可能不會通過CSS驗證,因為語句沒有用逗號隔開。
十、:focus
這是另外一個偽類需要在這里被提及的,因為所有的非IE瀏覽器,都支持這個屬性。:focus偽類允許你聲明一個特別的樣式,當(dāng)一個頁面元素成為鍵 盤(鼠標(biāo))焦點的時候,將該樣式動態(tài)的應(yīng)用到該元素上。這在表單元素上非常有用,因為你可以在一個輸入框被選中的時候給它添加一個邊框。
下面的樣式將在輸入框成為鍵盤焦點的時候添加一個紅色的邊框:
input:focus {
border: 1px solid #f00;
}
相關(guān)文章
- CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋2025-04-16
CSS Padding 和 Margin 區(qū)別全解析
CSS 中的 padding 和 margin 是兩個非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實際項目中使用它們2025-04-07- will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-07
- 在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實現(xiàn)復(fù)雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將2025-04-07
css中的 vertical-align與line-height作用詳解
文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會失效
z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用2025-03-21- 文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等2025-03-18
CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)
本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標(biāo)懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起2025-03-10前端 CSS 動態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對象語法和數(shù)組語法,通過對象語法,可以根據(jù)條件動態(tài)切換類名或樣式;通過數(shù)組語法,可以同時綁定多個類名或樣式,此外2025-02-26