10個IE瀏覽器不支持的很有用CSS屬性

 儘管我們對CSS已經非常熟悉,應付日常的工作或在各個瀏覽器中搞定CSS的兼容性已經很得心應手,但是並不是所有的CSS屬性都是那麼的常用。在本文中,讓我們看看10個可能非常有用但是在IE瀏覽器中(主要是IE6和IE7)卻不能使用的CSS屬性。

  (請注意,本文發表時尚未測試這些屬性在IE8中的表現。我稍後會做一個測試頁面,用來測試這些屬性在所以IE瀏覽器中的表現。)

  1、Outline

  在調試CSS問題的時候,我常常在指定元素上添加border來精確的查看該元素會發生什麼並幫助確定問題的來源。這常常是有效的,因爲它可以在佈局上給我更加具體的可視性。但是如果是塊級元素,這可能會發生某些錯誤——在任何塊級元素上添加1px的邊框很可能會影響到佈局,它會讓這個元素的寬度額外增加2px。

  outline屬性是完美的替代者,因爲它可以在不影響文檔流的情況下呈現該對象。但是IE6 和IE7不支持outline屬性,所以,它不能在這兩個瀏覽器中用於調試。

  2、Inherit(值)

  在CSS開發中有很多這樣的例子:通過在特定元素上設置某些樣式來告訴該元素來“繼承”它父級元素的所有已添加的屬性,這樣你就可以避免相當多的鍵盤輸入。

  這可以通過設置inherit來很容易的實現。這可能很有用。比如,當重寫background屬性的時候,常常會有很多的文字在該屬性中(色彩、圖片的URL地址、位置等)。所以,與其重新寫這些值,你可能僅僅想要考慮中的元素和其父級元素有相同的背景屬性,一個inherit值就可以搞定一切——這顯然大大的節省了鍵盤輸入。

  不幸的是,inherit值在IE6和IE7不被支持(除了用於direction(文字方向)和visibility屬性)。

  某人說,代碼就像女人的裙子——越短越好,看來IE會阻礙我們這個願望的實現。

  3、Empty-Cells

  該屬性只用於table或者”display”屬性被設置爲”table-cell”的元素。如果你動態的爲一個table添加內容,就可能會遇到某個單元格的內容爲空的情況,然後你又不希望這個空的單元格的邊框、背景色、背景圖片等隱藏掉。

  使用“empty-cells: hide”就能解決這個問題,它會將可能出現這種情況的單元格完全隱藏掉。

  Internet Explorer不支持empty-cells屬性。

  4、Caption-Side

  說到table的屬性,這個屬性用於聲明顯示在表格的側欄的表格標題。它接受top、bottom、left 和right 四個值。Internet Exporer不支持這個屬性,table的標題在IE6和IE7中將總是出現在表格的頂部。

  5、Counter-Increment/Counter-Reset

  有序列表(<ol>)非常方便,因爲它可以省去你手工添加遞增數字的麻煩,而且它允許你不用更改數字就能改變列表的序列。

  CSS 擁有counter-increment和counter-reset屬性,它允許你用來自動生成遞增數字到幾乎所有的HTML元素上,就像有序列表的效果一樣。

  這裏有個示例:

h2 {counter-increment: headers;}
h2:before {content: counter(headers) ". ";}

  上面的樣式將在所有的<h2>標籤前面自動添加遞增的數字,而且允許你在h2標籤上實現和li標籤同樣的的效果。

  但是IE6,IE7甚至Safari(直到3.x版本)還不支持這些屬性。當然,IE6也不支持:before僞元素。

  6、Min-Height

  有時,一個網站的設計或佈局結構需要一個有固定高度的內容區域,否則特定的視覺效果就會丟掉。這可能會因爲一個漸變背景、一個獨特的下拉列表、或者可能是因爲PS出來的很酷的發光效果。但是有的時候,頁面中的內容會比較多,而頁面卻不能像預期那樣展開。

  這個時候就需要用到min-height屬性了,因爲它可以告訴瀏覽器在一個特定的塊級元素上渲染最小的高度,不管內容的實際高度是否達到了這個最小高度。然後呢,如果內容超出了最小高度,該元素就會適度的擴展開。

  使用min-height唯一需要注意到的是它在IE6中不被支持。我們都知道IE6在(緩慢的)退出歷史舞臺,但是有的客戶可能仍然要求他們的網站支持這個該死的瀏覽器。

  不過令人高興的是,IE6渲染height的值的方法正好和其它瀏覽器渲染“min-height”的方式一樣,所以你只需要一個針對IE6的hack或獨立的樣式表來爲該元素添加特定的height,這個問題就解決了。

  IE6同樣無視min-width、max-height和max-width,但是上述方法在這些屬性上也是可行的。

  7、:hover

  從技術上來說,:hover只是一個僞類,但是它在IE6中不被支持(IE7和IE8支持)。:hover僞類允許你在元素上添加任何的鼠標經過樣式。這非常有用,可以避免(至少在某種程度上)使用JavaScript。

  但是如果你的網站,需要完全支持IE6,特別是在中國這種IE6一手遮天的情況下,那麼你就必須考慮取消使用這個僞類,除非相關的標籤有個”hred”屬性,比如<a>標籤。而且如果要實現這種效果,可能必須藉助於javascript和額外的樣式。

  8、Display

  Display通常被設置爲這三個值中的一個:block、inline和none。“得益於”IE,Display的其它值很少被用到。這些值包括inline-block、table、inline-table和table-cell等,這些屬性對於解決一些特殊的佈局問題時,是很有用的。

  所以,儘管IE確實支持Display的這三個基本屬性,但是它基本上不支持其它屬性。

  其實,IE8對display的屬性支持已經相當完整了。不過,對於inline-block屬性,IE6/7只支持本身爲inline的元素。

  9、Clip

  這是一個在特殊情況下能派上用場的很有趣的CSS屬性。它可能和不可預知的、動態生成的內容結合起來。簡單來說,這個屬性允許你在一個特定的元素上指定隱藏區域——也可以理解爲,在一個絕對定位的元素中,按照一定的設置來裁剪該元素的顯示區域,超出該區域的內容會被隱藏掉。語法看起來像這樣的:


div.clipped {
 padding: 20px;
 width: 400px;
 height: 400px;
 clip: rect(20px, 300px, 200px, 100px);
 position: absolute;
 }
 

  修剪只能用於一個絕對定位的元素,而且只用使用矩形區域。括號內的數字劃出的區域(200px*180px大小)爲可見區域,該區域以外的內容不可見或者被剪切掉。

  技術上來講,clip屬性被IE支持,但是隻支持無逗號的語法,比如


div.clipped {
 padding: 20px;
 width: 400px;
 height: 400px;
 clip: rect(20px 300px 200px 100px);
 position: absolute;
 }
 

  上面的樣式(rect後面括號裏的屬性沒有用逗號隔開)在大多數瀏覽器下都可運行,但是可能不會通過CSS驗證,因爲語句沒有用逗號隔開。

  10、:focus

  這是另外一個僞類需要在這裏被提及的,因爲所有的非IE瀏覽器,都支持這個屬性。:focus僞類允許你聲明一個特別的樣式,當一個頁面元素成爲鍵盤(鼠標)焦點的時候,將該樣式動態的應用到該元素上。這在表單元素上非常有用,因爲你可以在一個輸入框被選中的時候給它添加一個邊框。

  下面的樣式將在輸入框成爲鍵盤焦點的時候添加一個紅色的邊框:

input:focus {
 border: 1px solid #f00;
 }

  這就是本文的全部了,翻譯完成之後,神飛也受益匪淺,這10個屬性中,有我們常用的,更有我們不常用卻非常有用的——CSS學無止境。

發佈了19 篇原創文章 · 獲贊 6 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章