還不是因為瀏覽器廠商太多了!
chrome,frirefox,safari,edge,ie6,ie7,ie8,ie9...360安全瀏覽器,qq瀏覽器,世界之窗,tt,搜狗,opera,maxthon(傲遊)……
關鍵是不同廠商,甚至同一廠商不同版本,對同一段css的解析效果也不一致,這就導致了頁面顯示效果不統一,也就帶來了相容性問題。
多麼希望chrome能夠一統江湖啊~~
瀏覽器這麼多,我們也不可能每乙個都要去相容,對於使用者量一般的產品,把主流瀏覽器的適配做好,就已經很不錯啦。
根據世界市場權威調查機構netmarketshare公布的2023年10月各瀏覽器市場占有率,可以看出chrome的占有率達到了66.43%,這絕對是乙個振奮人心的好訊息。
今天,不想去關注太多細節問題, 比如那個css樣式需要我們去相容,而是想討論一下大的解決思路,主要包括4個方面,瀏覽器css樣式初始化、瀏覽器私有屬性,css hack語法和自動化外掛程式。
由於每個瀏覽器的css預設樣式不盡相同,所以最簡單有效的方式就是對其進行初始化,相信很多朋友都寫過這樣的**,在所有css開始前,先把marin和padding都設為0,以防不同瀏覽器的顯示效果不一樣。
*
關於瀏覽器css樣式初始化,經驗不豐富的話,可能也不知道該初始化什麼,這裡給大家推薦乙個庫,normalize.css,github star數量接近4萬,選取展示其中幾個樣式設定,如下
html
body
a img
通過css樣式初始化,相信能解決不少常規的相容性問題,接下來再看看瀏覽器的私有屬性。
我們經常會在某個css的屬性前新增一些字首,比如-webkit- ,-moz- ,-ms-,這些就是瀏覽器的私有屬性。
為什麼會出現私有屬性呢?這是因為制定html和css標準的組織w3c動作是很慢的。
通常,有w3c組織成員提出乙個新屬性,比如說圓角border-radius,大家都覺得好,但w3c制定標準,要走很複雜的程式,審查等。而瀏覽器商市場推廣時間緊,如果乙個屬性已經夠成熟了,就會在瀏覽器中加入支援。
但是為避免日後w3c公布標準時有所變更,會加入乙個私有字首,比如-webkit-border-radius,通過這種方式來提前支援新屬性。等到日後w3c公布了標準,border-radius的標準寫法確立之後,再讓新版的瀏覽器支援border-radius這種寫法。常用的字首有:
對於私有屬性的順序要注意,把標準寫法放到最後,相容性寫法放到前面
-webkit-transform:rotate(-3deg); /*為chrome/safari*/
-moz-transform:rotate(-3deg); /*為firefox*/
-ms-transform:rotate(-3deg); /*為ie*/
-o-transform:rotate(-3deg); /*為opera*/
transform:rotate(-3deg);
每個css屬性寫這麼一堆相容性**,無疑是對生命最大的浪費,後面我們會講一下通過自動化外掛程式來處理這塊。
有時我們需要針對不同的瀏覽器或不同版本寫特定的css樣式,這種針對不同的瀏覽器/不同版本寫相應的css code的過程,叫做css hack!
css hack的寫法大致歸納為3種:條件hack、屬性級hack、選擇符級hack。
條件hack主要針對ie瀏覽器進行一些特殊的設定
keywordsif後面跟的條件共包含6種選擇方式:是否、大於、大於或等於、小於、小於或等於、非指定版本
是否:指定是否ie或ie某個版本。關鍵字:空
大於:選擇大於指定版本的ie版本。關鍵字:gt(greater than)
大於或等於:選擇大於或等於指定版本的ie版本。關鍵字:gte(greater than or equal)
小於:選擇小於指定版本的ie版本。關鍵字:lt(less than)
小於或等於:選擇小於或等於指定版本的ie版本。關鍵字:lte(less than or equal)
非指定版本:選擇除指定版本外的所有ie版本。關鍵字:!
version
ie瀏覽器版本,如6、7、8
ie10及以上版本已將條件注釋特性移除,使用時需注意。
屬性hack就是在css樣式屬性名前加上一些只有特定瀏覽器才能識別的hack字首。
selector
_:選擇ie6及以下。連線線(中劃線)(-)亦可使用,為了避免與某些帶中劃線的屬性混淆,所以使用下劃線(_)更為合適。
*:選擇ie7及以下。諸如:(+)與(#)之類的均可使用,不過業界對(*)的認知度更高
9:選擇ie6+
0:選擇ie8+和opera15以下的瀏覽器
如在不同的ie瀏覽器中設定不同的顏色,注意順序:低版本的相容性寫法放到最後
.test
選擇符級hack是針對一些頁面表現不一致或者需要特殊對待的瀏覽器,在css選擇器前加上一些只有某些特定瀏覽器才能識別的字首進行hack。
selector
常見的選擇符級hack有
*html *字首只對ie6生效
*+html *+字首只對ie7生效
@media screen\9只對ie6/7生效
@media \0screen }只對ie8有效
@media \0screen\,screen\9}只對ie6/7/8有效
@media screen\0 } 只對ie8/9/10有效
@media screen and (min-width:0\0) } 只對ie9/10有效
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) } 只對ie10有效
* html .test /* for ie6 and earlier */
* + html .test /* for ie7 */
看到這裡,我不得不為前端人員自豪,這也太難了吧~~
不過花大力氣解決這些相容性問題, 並不能給我們技術上帶來什麼大的提公升,無非是給各個瀏覽器廠商填坑罷了,隨著時間的流逝,這些技術的價值也會越來越小,怎麼花最小的力氣解決css相容性問題,讓我們把更多的時間留給美好的生活,才是關鍵,好在有一些自動化外掛程式可以幫我們從繁重的相容性處理中解脫處理。
autoprefixer是一款自動管理瀏覽器字首的外掛程式,它可以解析css檔案並且新增瀏覽器字首到css內容裡,使用can i use(caniuse**)的資料來決定哪些字首是需要的。
把autoprefixe新增到資源構建工具(例如grunt)後,可以完全忘記有關css字首的東西,只需按照最新的w3c規範來正常書寫css即可。如果專案需要支援舊版瀏覽器,可修改browsers引數設定 。
//我們編寫的**
div
//自動補全的**,具體補全哪些由要相容的瀏覽器版本決定,可以自行設定div
目前webpack、gulp、grunt都有相應的外掛程式,如果還沒有使用,那就趕緊應用到我們的專案中吧,別再讓css相容性浪費你的時間! CSS瀏覽器相容性的4個解決方案
還不是因為瀏覽器廠商太多了!chrome,frirefox,safari,edge,ie6,ie7,ie8,ie9.360安全瀏覽器,qq瀏覽器,世界之窗,tt,搜狗,opera,maxthon 傲遊 關鍵是不同廠商,甚至同一廠商不同版本,對同一段css的解析效果也不一致,這就導致了頁面顯示效果不統...
CSS 瀏覽器相容性
1.不同瀏覽器的標籤預設的margin和padding不同 解決方案 所以需要有自己的格式化樣式 margin 0 padding 0 2.塊屬性標籤float後,又有橫行的margin情況下,在ie6顯示margin比設定的大 解決方案 在float的標籤樣式控制中加入 display inlin...
瀏覽器相容性
瀏覽器相容性是乙個很長久的話題,之所以前端需要面對瀏覽器相容性,是因為使用者的環境有不同的平台,不同的瀏覽器。不同的廠商之間為了相互競爭,對標準的實現不一樣。不同的瀏覽器有不同的核心。即使同乙個瀏覽器也有不同的版本,不同的版本對同一特性的支援情況也不盡相同。也可能某個瀏覽器的某個版本針對某個特性存在...