十個(gè)實(shí)用但不被IE6支持的CSS屬性
CSS屬性有很多值得學(xué)習(xí)的地方,這里和大家分享一下IE6不支持的十個(gè)實(shí)用的CSS屬性,希望本文介紹對(duì)你有所幫助。
IE6不支持的十個(gè)實(shí)用的CSS屬性
IE6對(duì)一些非常有用的CSS屬性完全不支持。比如mini-width,無(wú)人不抱怨IE6的CSS兼容性問(wèn)題。本文里面,介紹了10個(gè)很實(shí)但I(xiàn)E卻不支持的CSS屬性,列出這些屬性并不是為了數(shù)落IE(數(shù)落也沒(méi)用),而是你了解了哪些CSS屬性是IE不支持的,就更有針對(duì)性的去編寫CSS和Hack了。
一、Outline
在調(diào)試CSS問(wèn)題的時(shí)候,我常常在指定元素上添加border來(lái)精確的查看該元素會(huì)發(fā)生什么并幫助確定問(wèn)題的來(lái)源。這常常是有效的,因?yàn)樗梢栽诓季稚辖o我更加具體的可視性。但是如果是塊級(jí)元素,這可能會(huì)發(fā)生某些錯(cuò)誤——在任何塊級(jí)元素上添加1px的邊框很可能會(huì)影響到布局,它會(huì)讓這個(gè)元素的寬度額外增加2px。
outline屬性是完美的替代者,因?yàn)樗梢栽诓挥绊懳臋n流的情況下呈現(xiàn)該對(duì)象。但是IE6和IE7不支持outline屬性,所以,它不能在這兩個(gè)瀏覽器中用于調(diào)試。
二、Inherit(值)
在CSS開發(fā)中有很多這樣的例子:通過(guò)在特定元素上設(shè)置某些樣式來(lái)告訴該元素來(lái)“繼承”它父級(jí)元素的所有已添加的屬性,這樣你就可以避免相當(dāng)多的鍵盤輸入。
這可以通過(guò)設(shè)置inherit來(lái)很容易的實(shí)現(xiàn)。這可能很有用。比如,當(dāng)重寫background屬性的時(shí)候,常常會(huì)有很多的文字在該屬性中(色彩、圖片的URL地址、位置等)。所以,與其重新寫這些值,你可能僅僅想要考慮中的元素和其父級(jí)元素有相同的背景屬性,一個(gè)inherit值就可以搞定一切——這顯然大大的節(jié)省了鍵盤輸入。
不幸的是,inherit值在IE6和IE7不被支持(除了用于direction(文字方向)和visibility屬性)。
某人說(shuō),代碼就像女人的裙子——越短越好,看來(lái)IE會(huì)阻礙我們這個(gè)愿望的實(shí)現(xiàn)。
三、Empty-Cells
該屬性只用于table或者”display”屬性被設(shè)置為”table-cell”的元素。如果你動(dòng)態(tài)的為一個(gè)table添加內(nèi)容,就可能會(huì)遇到某個(gè)單元格的內(nèi)容為空的情況,然后你又不希望這個(gè)空的單元格的邊框、背景色、背景圖片等隱藏掉。
使用”empty-cells:hide”就能解決這個(gè)問(wèn)題,它會(huì)將可能出現(xiàn)這種情況的單元格完全隱藏掉。
InternetExplorer不支持empty-cells屬性。
四、Caption-Side
說(shuō)到table的屬性,這個(gè)屬性用于聲明顯示在表格的側(cè)欄的表格標(biāo)題。它接受top、bottom、left和right四個(gè)值。InternetExporer不支持這個(gè)屬性,table的標(biāo)題在IE6和IE7中將總是出現(xiàn)在表格的頂部。
五、Counter-Increment/Counter-Reset
有序列表(
- )非常方便,因?yàn)樗梢允∪ツ闶止ぬ砑舆f增數(shù)字的麻煩,而且它允許你不用更改數(shù)字就能改變列表的序列。
- h2{counter-increment:headers;}
- h2:before{content:counter(headers)".";}
- div.clipped{
- padding:20px;
- width:400px;
- height:400px;
- clip:rect(20px,300px,200px,100px);
- position:absolute;
- }
- div.clipped{
- padding:20px;
- width:400px;
- height:400px;
- clip:rect(20px300px200px100px);
- position:absolute;
- }
- input:focus{
- border:1pxsolid#f00;
- }
CSS擁有counter-increment和counter-reset屬性,它允許你用來(lái)自動(dòng)生成遞增數(shù)字到幾乎所有的HTML元素上,就像有序列表的效果一樣。
這里有個(gè)示例:
ExampleSourceCode
上面的樣式將在所有的
標(biāo)簽前面自動(dòng)添加遞增的數(shù)字,而且允許你在h2標(biāo)簽上實(shí)現(xiàn)和li標(biāo)簽同樣的的效果。
但是IE6,IE7甚至Safari(直到3.x版本)還不支持這些屬性。當(dāng)然,IE6也不支持:before偽元素。#p#
六、Min-Height
有時(shí),一個(gè)網(wǎng)站的設(shè)計(jì)或布局結(jié)構(gòu)需要一個(gè)有固定高度的內(nèi)容區(qū)域,否則特定的視覺(jué)效果就會(huì)丟掉。這可能會(huì)因?yàn)橐粋€(gè)漸變背景、一個(gè)獨(dú)特的下拉列表、或者可能是因?yàn)镻S出來(lái)的很酷的發(fā)光效果。但是有的時(shí)候,頁(yè)面中的內(nèi)容會(huì)比較多,而頁(yè)面卻不能像預(yù)期那樣展開。
這個(gè)時(shí)候就需要用到min-height屬性了,因?yàn)樗梢愿嬖V瀏覽器在一個(gè)特定的塊級(jí)元素上渲染最小的高度,不管內(nèi)容的實(shí)際高度是否達(dá)到了這個(gè)最小高度。然后呢,如果內(nèi)容超出了最小高度,該元素就會(huì)適度的擴(kuò)展開。
使用min-height唯一需要注意到的是它在IE6中不被支持。我們都知道IE6在(緩慢的)退出歷史舞臺(tái),但是有的客戶可能仍然要求他們的網(wǎng)站支持這個(gè)該死的瀏覽器。
不過(guò)令人高興的是,IE6渲染height的值的方法正好和其它瀏覽器渲染“min-height”的方式一樣,所以你只需要一個(gè)針對(duì)IE6的hack或獨(dú)立的樣式表來(lái)為該元素添加特定的height,這個(gè)問(wèn)題就解決了。
IE6同樣無(wú)視min-width、max-height和max-width,但是上述方法在這些屬性上也是可行的。
七、:hover
從技術(shù)上來(lái)說(shuō),:hover只是一個(gè)偽類,但是它在IE6中不被支持(IE7和IE8支持)。:hover偽類允許你在元素上添加任何的鼠標(biāo)經(jīng)過(guò)樣式。這非常有用,可以避免(至少在某種程度上)使用JavaScript。
但是如果你的網(wǎng)站,需要完全支持IE6,特別是在中國(guó)這種IE6一手遮天的情況下,那么你就必須考慮取消使用這個(gè)偽類,除非相關(guān)的標(biāo)簽有個(gè)”href”屬性,比如標(biāo)簽。而且如果要實(shí)現(xiàn)這種效果,可能必須借助于javascript和額外的樣式。
八、Display
Display通常被設(shè)置為這三個(gè)值中的一個(gè):block、inline和none?!暗靡嬗凇盜E,Display的其它值很少被用到。這些值包括inline-block、table、inline-table和table-cell等,這些屬性對(duì)于解決一些特殊的布局問(wèn)題時(shí),是很有用的。
所以,盡管IE確實(shí)支持Display的這三個(gè)基本屬性,但是它基本上不支持其它屬性。
其實(shí),IE8對(duì)display的屬性支持已經(jīng)相當(dāng)完整了。不過(guò),對(duì)于inline-block屬性,IE6/7只支持本身為inline的元素。
九.Clip
這是一個(gè)在特殊情況下能派上用場(chǎng)的很有趣的CSS屬性。它可能和不可預(yù)知的、動(dòng)態(tài)生成的內(nèi)容結(jié)合起來(lái)。簡(jiǎn)單來(lái)說(shuō),這個(gè)屬性允許你在一個(gè)特定的元素上指定隱藏區(qū)域——也可以理解為,在一個(gè)絕對(duì)定位的元素中,按照一定的設(shè)置來(lái)裁剪該元素的顯示區(qū)域,超出該區(qū)域的內(nèi)容會(huì)被隱藏掉。語(yǔ)法看起來(lái)像這樣的:
ExampleSourceCode
修剪只能用于一個(gè)絕對(duì)定位的元素,而且只用使用矩形區(qū)域。括號(hào)內(nèi)的數(shù)字劃出的區(qū)域(200px*180px大小)為可見區(qū)域,該區(qū)域以外的內(nèi)容不可見或者被剪切掉。
技術(shù)上來(lái)講,clip屬性被IE支持,但是只支持無(wú)逗號(hào)的語(yǔ)法,比如
ExampleSourceCode
上面的樣式(rect后面括號(hào)里的屬性沒(méi)有用逗號(hào)隔開)在大多數(shù)瀏覽器下都可運(yùn)行,但是可能不會(huì)通過(guò)CSS驗(yàn)證,因?yàn)檎Z(yǔ)句沒(méi)有用逗號(hào)隔開。
十、:focus
這是另外一個(gè)偽類需要在這里被提及的,因?yàn)樗械姆荌E瀏覽器,都支持這個(gè)屬性。:focus偽類允許你聲明一個(gè)特別的樣式,當(dāng)一個(gè)頁(yè)面元素成為鍵盤(鼠標(biāo))焦點(diǎn)的時(shí)候,將該樣式動(dòng)態(tài)的應(yīng)用到該元素上。這在表單元素上非常有用,因?yàn)槟憧梢栽谝粋€(gè)輸入框被選中的時(shí)候給它添加一個(gè)邊框。
下面的樣式將在輸入框成為鍵盤焦點(diǎn)的時(shí)候添加一個(gè)紅色的邊框:
ExampleSourceCode
文章來(lái)源:Div-CSS.net設(shè)計(jì)網(wǎng)參考:http://www.div-CSS.net/div_CSS/topic/index.asp?id=6840
【編輯推薦】