瀏覽器兼容

什么是 CSS hack

  • 由于不同廠商的瀏覽器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等红选,或者是同一廠商的瀏覽器的不同版本,如IE6和IE7,對CSS的解析認識不完全一樣粟矿,因此會導致生成的頁面效果不一樣,得不到我們所需要的頁面效果璧针。
  • 這個時候我們就需要針對不同的瀏覽器去寫不同的CSS嚷炉,讓它能在不同的瀏覽器中也能得到我們想要的頁面效果。

談一談瀏覽器兼容的思路

  1. 要不要做
  • 產品的角度(產品的受眾探橱、受眾的瀏覽器比例申屹、效果優(yōu)先還是基本功能優(yōu)先)
  • 成本的角度 (有無必要做某件事)
  1. 做到什么程度
  • 讓哪些瀏覽器支持哪些效果
  1. 如何做

漸進增強和優(yōu)雅降級

  • 漸進增強(progressive enhancement): 針對低版本瀏覽器進行構建頁面魏宽,保證最基本的功能,然后再針對高級瀏覽器進行效果决乎、交互等改進和追加功能達到更好的用戶體驗
  • 優(yōu)雅降級 (graceful degradation): 一開始就構建完整的功能队询,然后再針對低版本瀏覽器進行兼容。

列舉5種以上瀏覽器兼容的寫法

1.瀏覽器兼容問題:塊屬性標簽float后构诚,又有橫行的margin情況下蚌斩,在IE6顯示margin比設置的大

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

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

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

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

2.瀏覽器兼容問題:設置較小高度標簽(一般小于10px),在IE6受裹,IE7中高度超出自己設置高度

問題癥狀:IE6碌补、7里這個標簽的高度不受控制,超出自己設置的高度

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

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

3.瀏覽器兼容問題四:行內屬性標簽坑律,設置display:block后采用float布局岩梳,又有橫行的margin的情況,IE6間距bug

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

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

備注:行內屬性標簽晃择,為了設置寬高冀值,我們需要設置display:block;(除了input標簽比較特殊)。在用float布局并有橫向的margin后宫屠,在IE6下列疗,他就具有了塊屬性float后的橫向margin的bug。不過因為它本身就是行內屬性標簽浪蹂,所以我們再加上display:inline的話抵栈,它的高寬就不可設了告材。這時候我們還需要在display:inline后面加入display:talbe。

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

問題癥狀:幾個img標簽放在一起的時候古劲,有些瀏覽器會有默認的間距斥赋,加了通配符也不起作用。

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

備注:因為img標簽是行內屬性標簽产艾,所以只要不超出容器寬度疤剑,img標簽都會排在一行里,但是部分瀏覽器的img標簽之間會有個間距闷堡。去掉這個間距使用float是正道隘膘。

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

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

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

備注:在B/S系統(tǒng)前端開時棘幸,有很多情況下我們又這種需求。當內容小于一個值(如300px)時倦零。容器的高度為300px误续;當內容高度大于這個值時,容器高度被撐高扫茅,而不是出現(xiàn)滾動條蹋嵌。這時候我們就會面臨這個兼容性問題。

以下工具/名詞是做什么的

  • 條件注釋
    條件注釋 (conditional comment) 是于HTML源碼中被 Microsoft Internet Explorer 有條件解釋的語句葫隙。條件注釋可被用來向 Internet Explorer 提供及隱藏代碼
  • IE Hack
    使用特殊的符號或者方式寫出只有IE瀏覽器可以解析的代碼栽烂,有CSS屬性前綴法、選擇器前綴法以及IE條件注釋法
  • js 能力檢測
    使用JS的語法檢測瀏覽器支持的屬性恋脚,以便展示效果
  • html5shiv.js
    用于解決IE9以下版本瀏覽器對HTML5新增標簽不識別腺办,并導致CSS不起作用的問題。
  • respond.js
    讓不支持css3 Media Query的瀏覽器包括IE6-IE8等其他瀏覽器支持查詢糟描。
  • css reset
    通過重新定義標簽樣式怀喉,“覆蓋”瀏覽器的CSS默認屬性
  • normalize.css
    Normalize.css 只是一個很小的CSS文件,但它在默認的HTML元素樣式上提供了跨瀏覽器的高度一致性船响。相比于傳統(tǒng)的CSS reset躬拢,Normalize.css是一種現(xiàn)代的、為HTML5準備的優(yōu)質替代方案见间。
  • Modernizr
    Modernizr是一個 JavaScript 庫聊闯,用于檢測用戶瀏覽器的 HTML5 與 CSS3 特性。
  • postCSS
    PostCSS是一個JS插件轉換樣式表的工具米诉。這些插件能夠檢驗你的CSS菱蔬、支持變量和混合,轉化css3的新特性語法、行內圖片等拴泌。

常見屬性的兼容情況

  • inline-block: >=ie8
  • min-width/min-height: >=ie8
  • :before,:after: >=ie8
  • div:hover: >=ie7
  • inline-block: >=ie8
  • background-size: >=ie9
  • 圓角: >= ie9
  • 陰影: >= ie9
  • 動畫/漸變: >= ie10

一般在哪個網(wǎng)站查詢屬性兼容性魏身?

caniuse.com 查CSS屬性兼容
browserhacks 查 Hack 的寫法

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市弛针,隨后出現(xiàn)的幾起案子叠骑,更是在濱河造成了極大的恐慌,老刑警劉巖削茁,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宙枷,死亡現(xiàn)場離奇詭異,居然都是意外死亡茧跋,警方通過查閱死者的電腦和手機慰丛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瘾杭,“玉大人诅病,你說我怎么就攤上這事≈嗨福” “怎么了贤笆?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長讨阻。 經常有香客問我芥永,道長,這世上最難降的妖魔是什么钝吮? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任埋涧,我火速辦了婚禮,結果婚禮上奇瘦,老公的妹妹穿的比我還像新娘棘催。我一直安慰自己,他們只是感情好耳标,可當我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布醇坝。 她就那樣靜靜地躺著,像睡著了一般麻捻。 火紅的嫁衣襯著肌膚如雪纲仍。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天贸毕,我揣著相機與錄音,去河邊找鬼夜赵。 笑死明棍,一個胖子當著我的面吹牛,可吹牛的內容都是我干的寇僧。 我是一名探鬼主播摊腋,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼沸版,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了兴蒸?” 一聲冷哼從身側響起视粮,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎橙凳,沒想到半個月后蕾殴,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡岛啸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年钓觉,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坚踩。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡荡灾,死狀恐怖,靈堂內的尸體忽然破棺而出瞬铸,到底是詐尸還是另有隱情批幌,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布嗓节,位于F島的核電站荧缘,受9級特大地震影響,放射性物質發(fā)生泄漏赦政。R本人自食惡果不足惜胜宇,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望恢着。 院中可真熱鬧桐愉,春花似錦、人聲如沸掰派。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽靡羡。三九已至系洛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間略步,已是汗流浹背描扯。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留趟薄,地道東北人绽诚。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親恩够。 傳聞我的和親對象是個殘疾皇子卒落,可洞房花燭夜當晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,728評論 1 92
  • 序章 談談“瀏覽器兼容性”的問題腰湾?很多前端的面試或筆試中,都有比較籠統(tǒng)的“說說你所知道的各瀏覽器存在的兼容問題”钦购,...
    麻辣小隔壁閱讀 3,036評論 1 57
  • 一檐盟、如何調試 IE 瀏覽器 IE7以上版本自帶的開發(fā)者工具,IE6可以用border的方法押桃;例:IE11的開發(fā)者工...
    __Qiao閱讀 1,121評論 2 17
  • 瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補丁和內補丁不同問題癥狀:隨便寫幾個標簽葵萎,不加樣式控制的情況下,各自的m...
    追卓2018閱讀 1,297評論 0 2
  • ? JavaScript 3 1. HTML對象獲取問題 32. const問題 33. event.x與even...
    橫沖直撞666閱讀 3,182評論 0 7