css瀏覽器不兼容原因分析及解決辦法第2/2頁
更新時(shí)間:2008年08月23日 21:04:43 作者:
瀏覽器的不兼容,大家肯定都是深惡痛絕的,往往我們只是去做修補(bǔ),卻忘了更重要的事情,那就是追溯根源,避免類似的不兼容再次出現(xiàn)。
11.img下的留白,大家看這段代碼有啥問題:
<div>
<img src=”” src=”” />
</div>
把div的border打開,你發(fā)現(xiàn)圖片底部不是緊貼著容器底部的,是img后面的空白字符造成,要消除必須這樣寫
<div>
<img src=”” src=”” /></div>
后面兩個(gè)標(biāo)簽要緊挨著。ie7下這個(gè)bug 依然存在。解決方案:給img設(shè)定 display:block。
12.失去line-height。<div style=”line-height:20px”><img />文字</div>,很遺憾,在ie6下單行文字 line-height 效果消失了。。。,原因是<img />這個(gè)inline-block元素和inline元素寫在一起了。解決方案:讓img 和文字都 float起來。
引申:大家知道img 的align 有 text-top,middle,absmiddle啊什么的,你可以嘗試去調(diào)整img 和文字讓他們?cè)趇e和ff下能一致,你會(huì)發(fā)現(xiàn)怎么調(diào)都不會(huì)讓你滿意。索性讓img 和文字都 float起來,用margin 調(diào)整。
13.鏈接的hover狀態(tài)。a:hover img{width:300px} 我們想讓鼠標(biāo)hover時(shí),鏈接里包含的圖片寬度變化,可惜在ie6下無效,ie7、ff下有效。
14.非鏈接的hover狀態(tài)。div:hover{} 這樣的樣式ie6是不認(rèn)的,在ie7、ff下才有效果。
15.block化的a鏈接,其內(nèi)套absolute層,absolute層內(nèi)放置img,ie下,鼠標(biāo)點(diǎn)擊img不會(huì)有鏈接效果,ff、op下正常。
想不出來了,以后想到再加吧。上面的諸多問題如果你掌握了其中奧妙,90%的不兼容問題不需要另起css hack的。
16.無法徹底清除的float。如果讓ul下的li具有了float屬性,如何clear浮動(dòng)的li呢?<ul><li class=”c”></li></ul> 或者 <ul><li><div>class=”c”></div></li></ul> 或者 <ul><li></li><div>class=”c”></div></ul> 或者 <ul><li></li></ul><div>class=”c”></div> 或者上述的組合?這個(gè)問題,我無法給出解答。下面有個(gè)例子與此相關(guān)
<!DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Transitional//EN http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd>
<style type=text/css>
.c{clear:both;overflow:hidden;+overflow:visible}
.bd{border:1px solid red}
ul.ex{list-style:none;}
ul.ex li{float:left;border:1px solid green;}
</style>
<ul class=ex>
<li>sfsdfsfdf</li>
<li>sfsdfsfdf</li>
</ul>
<div class=c></div>
<div class=bd style=margin-top:19px>sfsdfsfdf</div>
請(qǐng)?jiān)趇e下 測(cè)試,僅僅將 margin-top:19px 改為margin-top:20px 你發(fā)現(xiàn)什么了?要素:doctype必須有,ie6、ie7下margin-top:19px還好好的,margin-top:20px 就出問題了,無法解釋。。。大家還可以將 clear 層換不同的位置測(cè)試。
解決方案:給ul 屬性zoom:1 (給li 加zoom:1 沒用)
引申:clear層應(yīng)該單獨(dú)使用。也許你為了節(jié)省代碼把clear屬性直接放到下面的一個(gè)內(nèi)容層,這樣有問題,不僅僅是ff和op下失去margin效果,ie下某些margin值也會(huì)失效
<div style=”background:red;float:left;”>dd</div>
<div style=”clear:both;margin-top:18px;background:green”>ff</div>
17.ie下overflow:hidden對(duì)其下的絕對(duì)層position:absolute或者相對(duì)層position:relative無效。解決方案:給overflow:hidden加position:relative或者position:absolute。另,ie6支持overflow-x或者overflow-y的特性,ie7、ff不支持。
18.ie6下嚴(yán)重的bug,float元素如沒定義寬度,內(nèi)部如有div定義了height或zoom:1,這個(gè)div就會(huì)占滿一整行,即使你給了寬度。float元素如果作為布局用或復(fù)雜的容器,都要給個(gè)寬度的。
19.ie6下的bug,絕對(duì)定位的div下包含相對(duì)定位的div,如果給內(nèi)層相對(duì)定位的div高度height具體值,內(nèi)層相對(duì)層將具有100%的width值,外層絕對(duì)層將被撐大。解決方案給內(nèi)層相對(duì)層float屬性。
20.ie6下的bug,<head></head>內(nèi)有<base target=”_blank”/>的情況下,position:relative層下的float層內(nèi)文字無法選中。這個(gè)bug迫使我修公用樣式庫。
21.終于來了個(gè)ff的缺點(diǎn)。width:100%這個(gè)東西在ie里用很方便,會(huì)向上逐層搜索width值,忽視浮動(dòng)層的影響,ff下搜索至浮動(dòng)層結(jié)束,如此,只能給中間的所有浮動(dòng)層加width:100%才行,累啊。opera這點(diǎn)倒學(xué)乖了跟了ie。
您可能感興趣的文章:
- 多瀏覽器兼容的動(dòng)態(tài)加載 JavaScript 與 CSS
- js+css實(shí)現(xiàn)的簡單易用兼容好的分頁
- Css瀏覽器兼容的解決方法
- div+css+js實(shí)現(xiàn)無縫滾動(dòng)類似marquee無縫滾動(dòng)兼容firefox
- div+CSS 兼容小摘
- CSS Hack 匯總速查手冊(cè)瀏覽器兼容必會(huì)
- 使css兼容IE8的小技巧
- JavaScript獲取鼠標(biāo)移動(dòng)時(shí)的坐標(biāo)(兼容IE8、chome谷歌、Firefox)
- javascript中實(shí)現(xiàn)兼容JAVA的hashCode算法代碼分享
- 兼容最新firefox、chrome和IE的javascript圖片預(yù)覽實(shí)現(xiàn)代碼
- JavaScript在IE和FF下的兼容性問題
- css與javascript跨瀏覽器兼容性總結(jié)
相關(guān)文章
學(xué)習(xí)WEB標(biāo)準(zhǔn)總結(jié)的一些CSS/XHTML知識(shí)小結(jié)
制作網(wǎng)頁過程中,總會(huì)遇到一些CSS/XHTML的各種問題,下面大體的總結(jié)了下2008-09-09html小技巧之td,div標(biāo)簽里內(nèi)容不換行
這篇文章主要介紹了td,div標(biāo)簽里內(nèi)容不換行的方法,需要的朋友可以參考下2014-05-05網(wǎng)頁布局+純CSS縱向下拉菜單 IE6/IE7兼容
網(wǎng)頁布局+純CSS縱向下拉菜單 IE6/IE7兼容...2007-11-11用margin和overflow屬性實(shí)現(xiàn)div間距的方法
用margin和overflow屬性實(shí)現(xiàn)div間距的方法...2007-12-12web標(biāo)準(zhǔn)知識(shí)——從p開始,循序漸進(jìn)
從今天開始,我將全面的共享出我所能理解的所有WEB標(biāo)準(zhǔn)方面的知識(shí)放在這個(gè)“WEB標(biāo)準(zhǔn)能有多難?”的專欄里。當(dāng)然由于振之的水平有限,所講并非是完全正確的。在看了這個(gè)專欄的文章的時(shí)候要理性的分析,要有自己的判斷,歡迎各位朋友提出自己的看法與意見。2008-06-06CSS定位中Positoin、absolute、Relative的一些研究
用Div+CSS進(jìn)行網(wǎng)站布局時(shí),做一些浮動(dòng)層等特殊特殊效果時(shí)要考慮到定位問題。這就要用到Positoin屬性等。2008-10-10