1.什么是 CSS hack煎谍?
由于不同廠商的瀏覽器或者不同瀏覽器的版本(IE6-11龙屉,chorme/safari/opera/firefox等),對CSS的支持作岖、解析不同。導(dǎo)致了我們在編寫頁面的過程中辕万,為了獲得統(tǒng)一的頁面效果沉删,需要針對某些特定的瀏覽器或者瀏覽器版本編寫特定的CSS樣式,這一過程就叫做CSS hack砖茸。
CSS的分類:CSS大致有三種表現(xiàn)形式殴穴,IE條件注釋法(即html頭部引入if IE)hack,CSS選擇器加前綴劲够,CSS屬性加前綴休傍,實際項目中CSS hack 主要是針對不同IE瀏覽器版本的差別。
1.IE條件注釋法(即HTML條件注釋Hack):針對所有IE(注:IE10+已經(jīng)不再支持條件注釋): 炒瘸,針對IE6及以下版本: 寝衫。這類Hack不僅對CSS生效,對寫在判斷語句里面的所有代碼都會生效隘截。
2.選擇器前綴法(即選擇器Hack):例如 IE6能識別html .class{}汹胃,IE7能識別+html .class{}或者:first-child+html .class{}着饥。
3.屬性前綴法(即類內(nèi)部Hack):例如 IE6能識別下劃線""和星號" ",IE7能識別星號" * "宰掉,但不能識別下劃線"",IE6~IE10都認識"\9"孟害,但firefox前述三個都不能認識。
2.談一談瀏覽器兼容的思路
主要分三步:
1.要不要兼容击你?
產(chǎn)品的角度(產(chǎn)品的用戶谎柄、用戶的瀏覽器比例、效果優(yōu)先還是基本功能優(yōu)先)
成本的角度(值不值得的去做绒障,做了是否可以達到預(yù)期的回報)
boss說干咱就干
2.做到什么程度
支持哪些瀏覽器捍歪?支持到哪個版本糙臼?
3.如何做
根據(jù)兼容需求選擇框架或庫(jquery)
根據(jù)兼容需求選擇兼容工具(html5shiv.js、respond.js变逃、css reset揽乱、normalize.css、Modernizr)
postCss(可以自動給屬性加前綴)
條件注釋凰棉、CSS hack撒犀、JS能力檢測做一些修補
3.列舉5種以上瀏覽器兼容的寫法
(1)條件注釋
(2)屬性前綴
(3)清除浮動
(4)inline-block
(5)html5shiv.js荆姆,respond.js
在頁面頭部引入
html5shiv.js可以模擬html5標(biāo)簽的特性映凳,使不支持html5標(biāo)簽的瀏覽器也能使用html5標(biāo)簽。
respond.js則可以讓不支持CSS3 media query腐泻,min-width和max-width屬性的IE瀏覽器支持該屬性队询。
4.以下工具/名詞是做什么的
條件注釋: conditional comment 是HTML源碼中被IE有條件解釋的語句,條件注釋可以被用來向IE提供及隱藏代碼
IE Hack:針對IE瀏覽器的CSS hack
js 能力檢測:使用js檢測瀏覽器是否支持某些屬性和方法铆惑。
html5shiv.js:讓IE6-8識別html5新標(biāo)簽送膳,使其可以包裹元素叠聋,可以設(shè)置樣式。
respond.js:讓IE6-8支持css3媒體查詢碌补,實現(xiàn)響應(yīng)式效果。
css reset:去除瀏覽器的默認樣式镇匀,簡單粗暴的去除了所有html元素的默認樣式袜啃。
normalize.css:css reset的改良版,去除了導(dǎo)致不同瀏覽器渲染效果不同的一些樣式晰韵,同時保留了一些有用的默認樣式熟妓。
Modernizr:檢測瀏覽器是否支持html5和css3新特性的js庫滑蚯,根據(jù)檢測結(jié)果給html元素添加相應(yīng)的類名,以方便開發(fā)者根據(jù)這些類名進行相應(yīng)的樣式開發(fā)告材。
postCSS:根據(jù)不同瀏覽器給樣式添加相應(yīng)的前綴(例如-moz-, -webkit-等)斥赋,用戶只需設(shè)置樣式的標(biāo)準(zhǔn)寫法,postCSS會自動添加前綴疤剑。
5.一般在哪個網(wǎng)站查詢屬性兼容性?
1.http://caniuse.com/ 不僅可以查屬性還可以查標(biāo)簽2.http://browserhacks.com/ 可以查找不同瀏覽器的hack方法3.http://#baidu.com/data/browser 可以查詢用戶在不同瀏覽器疑故、不同瀏覽器版本纵势、不同終端、用戶群的屬性钦铁、用戶群的行為中的比例,有利于開發(fā)人員判斷是否有必要進行瀏覽器兼容以及兼容到哪個級別佛点。