常見瀏覽器兼容性問題與解決方案

所謂的瀏覽器兼容性問題豁陆,是指因為不同的瀏覽器對同一段代碼有不同的解析瓣戚,造成頁面顯示效果不統(tǒng)一的情況。在大多數(shù)情況下蜓斧,我們的需求是,無論用戶用什么瀏覽器來查看我們的網(wǎng)站或者登陸我們的系統(tǒng)睁冬,都應該是統(tǒng)一的顯示效果挎春。所以瀏覽器的兼容性問題是前端開發(fā)人員經常會碰到和必須要解決的問題。

在學習瀏覽器兼容性之前豆拨,我想把前端開發(fā)人員劃分為兩類:

第一類是精確按照設計圖開發(fā)的前端開發(fā)人員直奋,可以說是精確到1px的,他們很容易就會發(fā)現(xiàn)設計圖的不足施禾,并且在很少的情況下會碰到瀏覽器的兼容性問題脚线,而這些問題往往都死瀏覽器的bug,并且他們制作的頁面后期易維護弥搞,代碼重用問題少邮绿,可以說是比較牢固放心的代碼渠旁。

第二類是基本按照設計圖來開發(fā)的前端開發(fā)人員,很多細枝末節(jié)差距很大船逮,不如間距顾腊,行高,圖片位置等等經常會差幾px挖胃。某種效果的實現(xiàn)也是反復調試得到杂靶,具體為什么出現(xiàn)這種效果還模模糊糊,整體布局十分脆弱冠骄。稍有改動就亂七八糟伪煤。代碼為什么這么寫還不知所以然。這類開發(fā)人員往往經常為兼容性問題所困凛辣。修改好了這個瀏覽器又亂了另一個瀏覽器抱既。改來改去也毫無頭緒。其實他們碰到的兼容性問題大部分不應該歸咎于瀏覽器扁誓,而是他們的技術本身了防泵。

文章主要針對的是第一類,嚴謹型的開發(fā)人員蝗敢,因此這里主要從瀏覽器解析差異的角度來分析兼容性問題捷泞。(相關文章推薦:主流瀏覽器CSS 3和HTML 5兼容清單

瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補丁和內補丁不同

問題癥狀:隨便寫幾個標簽,不加樣式控制的情況下寿谴,各自的margin 和padding差異較大锁右。

碰到頻率:100%

解決方案:CSS里??? *{margin:0;padding:0;}

備注:這個是最常見的也是最易解決的一個瀏覽器兼容性問題,幾乎所有的CSS文件開頭都會用通配符*來設置各個標簽的內外補丁是0讶泰。

瀏覽器兼容問題二:塊屬性標簽float后咏瑟,又有橫行的margin情況下,在IE6顯示margin比設置的大

問題癥狀:常見癥狀是IE6中后面的一塊被頂?shù)较乱恍?/p>

碰到頻率:90%(稍微復雜點的頁面都會碰到痪署,float布局最常見的瀏覽器兼容問題)

解決方案:在float的標簽樣式控制中加入 display:inline;將其轉化為行內屬性

備注:我們最常用的就是div+CSS布局了码泞,而div就是一個典型的塊屬性標簽,橫向布局的時候我們通常都是用div float實現(xiàn)的狼犯,橫向的間距設置如果用margin實現(xiàn)余寥,這就是一個必然會碰到的兼容性問題。

瀏覽器兼容問題三:設置較小高度標簽(一般小于10px)悯森,在IE6宋舷,IE7,遨游中高度超出自己設置高度

問題癥狀:IE6瓢姻、7和遨游里這個標簽的高度不受控制肥缔,超出自己設置的高度

碰到頻率:60%

解決方案:給超出高度的標簽設置overflow:hidden;或者設置行高line-height 小于你設置的高度。

備注:這種情況一般出現(xiàn)在我們設置小圓角背景的標簽里汹来。出現(xiàn)這個問題的原因是IE8之前的瀏覽器都會給標簽一個最小默認的行高的高度续膳。即使你的標簽是空的,這個標簽的高度還是會達到默認的行高收班。

瀏覽器兼容問題四:行內屬性標簽坟岔,設置display:block后采用float布局,又有橫行的margin的情況摔桦,IE6間距bug

問題癥狀:IE6里的間距比超過設置的間距

碰到幾率:20%

解決方案:在display:block;后面加入display:inline;display:table;

備注:行內屬性標簽社付,為了設置寬高,我們需要設置display:block;(除了input標簽比較特殊)邻耕。在用float布局并有橫向的margin后鸥咖,在IE6下,他就具有了塊屬性float后的橫向margin的bug兄世。不過因為它本身就是行內屬性標簽啼辣,所以我們再加上display:inline的話,它的高寬就不可設了御滩。這時候我們還需要在display:inline后面加入display:talbe鸥拧。

瀏覽器兼容問題五:圖片默認有間距

問題癥狀:幾個img標簽放在一起的時候,有些瀏覽器會有默認的間距削解,加了問題一中提到的通配符也不起作用富弦。

碰到幾率:20%

解決方案:使用float屬性為img布局

備注:因為img標簽是行內屬性標簽,所以只要不超出容器寬度氛驮,img標簽都會排在一行里腕柜,但是部分瀏覽器的img標簽之間會有個間距。去掉這個間距使用float是正道矫废。(我的一個學生使用負margin盏缤,雖然能解決,但負margin本身就是容易引起瀏覽器兼容問題的用法磷脯,所以我禁止他們使用)

瀏覽器兼容問題六:標簽最低高度設置min-height不兼容

問題癥狀:因為min-height本身就是一個不兼容的CSS屬性蛾找,所以設置min-height時不能很好的被各個瀏覽器兼容

碰到幾率:5%

解決方案:如果我們要設置一個標簽的最小高度200px,需要進行的設置為:{min-height:200px; height:auto !important; height:200px; overflow:visible;}

備注:在B/S系統(tǒng)前端開時赵誓,有很多情況下我們又這種需求打毛。當內容小于一個值(如300px)時。容器的高度為300px俩功;當內容高度大于這個值時幻枉,容器高度被撐高,而不是出現(xiàn)滾動條诡蜓。這時候我們就會面臨這個兼容性問題熬甫。

瀏覽器兼容問題七:透明度的兼容CSS設置

做兼容頁面的方法是:每寫一小段代碼(布局中的一行或者一塊)我們都要在不同的瀏覽器中看是否兼容,當然熟練到一定的程度就沒這么麻煩了蔓罚。建議經常會碰到兼容性問題的新手使用椿肩。很多兼容性問題都是因為瀏覽器對標簽的默認屬性解析不同造成的瞻颂,只要我們稍加設置都能輕松地解決這些兼容問題。如果我們熟悉標簽的默認屬性的話郑象,就能很好的理解為什么會出現(xiàn)兼容問題以及怎么去解決這些兼容問題贡这。

/*?CSS?hack*/

我很少使用hacker的,可能是個人習慣吧厂榛,我不喜歡寫的代碼IE不兼容盖矫,然后用hack來解決宇驾。不過hacker還是非常好用的兰迫。使用hacker我可以把瀏覽器分為3類:IE6 ;IE7和遨游馏段;其他(IE8 chrome ff safari opera等)

◆IE6認識的hacker 是下劃線_ 和星號 *

◆IE7 遨游認識的hacker是星號 *

比如這樣一個CSS設置:

height:300px;*height:200px;_height:100px;

IE6瀏覽器在讀到height:300px的時候會認為高時300px柜砾;繼續(xù)往下讀湃望,他也認識*heihgt, 所以當IE6讀到*height:200px的時候會覆蓋掉前一條的相沖突設置局义,認為高度是200px喜爷。繼續(xù)往下讀,IE6還認識_height,所以他又會覆蓋掉200px高的設置萄唇,把高度設置為100px檩帐;

IE7和遨游也是一樣的從高度300px的設置往下讀。當它們讀到*height200px的時候就停下了另萤,因為它們不認識_height湃密。所以它們會把高度解析為200px,剩下的瀏覽器只認識第一個height:300px;所以他們會把高度解析為300px四敞。因為優(yōu)先級相同且想沖突的屬性設置后一個會覆蓋掉前一個泛源,所以書寫的次序是很重要的。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末忿危,一起剝皮案震驚了整個濱河市达箍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铺厨,老刑警劉巖缎玫,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異解滓,居然都是意外死亡赃磨,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門洼裤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來邻辉,“玉大人,你說我怎么就攤上這事≈岛В” “怎么了莹菱?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長雷客。 經常有香客問我芒珠,道長,這世上最難降的妖魔是什么搅裙? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮裹芝,結果婚禮上部逮,老公的妹妹穿的比我還像新娘。我一直安慰自己嫂易,他們只是感情好兄朋,可當我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著怜械,像睡著了一般颅和。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上缕允,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天峡扩,我揣著相機與錄音,去河邊找鬼障本。 笑死教届,一個胖子當著我的面吹牛,可吹牛的內容都是我干的驾霜。 我是一名探鬼主播案训,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼粪糙!你這毒婦竟也來了强霎?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤蓉冈,失蹤者是張志新(化名)和其女友劉穎城舞,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體洒擦,經...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡椿争,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了熟嫩。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秦踪。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出椅邓,到底是詐尸還是另有隱情柠逞,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布景馁,位于F島的核電站板壮,受9級特大地震影響,放射性物質發(fā)生泄漏合住。R本人自食惡果不足惜绰精,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望透葛。 院中可真熱鬧笨使,春花似錦、人聲如沸僚害。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽萨蚕。三九已至靶草,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間岳遥,已是汗流浹背奕翔。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留寒随,地道東北人糠悯。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像妻往,于是被迫代替她去往敵國和親互艾。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內容