解決CSS瀏覽器兼容性問(wèn)題的4種方案

前端是一個(gè)苦逼的職業(yè),不僅因?yàn)榧夹g(shù)更新快,而且要會(huì)的東西實(shí)在太多了,更讓人頭疼的是,還要面臨各種適配、兼容性問(wèn)題。
為什么會(huì)有瀏覽器兼容性問(wèn)題?
還不是因?yàn)闉g覽器廠商太多了!
Chrome,F(xiàn)rirefox,Safari,Edge,IE6,IE7,IE8,IE9...360安全瀏覽器,qq瀏覽器,世界之窗,TT,搜狗,opera,maxthon(傲游)……
關(guān)鍵是不同廠商,甚至同一廠商不同版本,對(duì)同一段CSS的解析效果也不一致,這就導(dǎo)致了頁(yè)面顯示效果不統(tǒng)一,也就帶來(lái)了兼容性問(wèn)題。
多么希望Chrome能夠一統(tǒng)江湖啊~~
目前各瀏覽器市場(chǎng)份額
瀏覽器這么多,我們也不可能每一個(gè)都要去兼容,對(duì)于用戶量一般的產(chǎn)品,把主流瀏覽器的適配做好,就已經(jīng)很不錯(cuò)啦。
根據(jù)百度流量研究院提供的2018年8月至2019年2月的數(shù)據(jù)可以看出,Chrome占比46.28%,IE系仍然占有很大比重,任重而道遠(yuǎn)啊~
CSS瀏覽器兼容性問(wèn)題的解決思路和方案
今天,不想去關(guān)注太多細(xì)節(jié)問(wèn)題, 比如那個(gè)css樣式需要我們?nèi)ゼ嫒?,而是想討論一下大的解決思路,主要包括4個(gè)方面,瀏覽器CSS樣式初始化、瀏覽器私有屬性,CSS hack語(yǔ)法和自動(dòng)化插件。
1. 瀏覽器CSS樣式初始化
由于每個(gè)瀏覽器的css默認(rèn)樣式不盡相同,所以最簡(jiǎn)單有效的方式就是對(duì)其進(jìn)行初始化,相信很多朋友都寫過(guò)這樣的代碼,在所有CSS開(kāi)始前,先把marin和padding都設(shè)為0,以防不同瀏覽器的顯示效果不一樣。
*{ margin: 0; padding: 0; }
關(guān)于瀏覽器CSS樣式初始化,經(jīng)驗(yàn)不豐富的話,可能也不知道該初始化什么,這里給大家推薦一個(gè)庫(kù),Normalize.css,github star數(shù)量接近3.4萬(wàn),選取展示其中幾個(gè)樣式設(shè)置,如下
html { line-height: 1.15; /* Correct the line height in all browsers */ -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS. */ } body { margin: 0; } a { background-color: transparent; /* Remove the gray background on active links in IE 10. */ } img { border-style: none; /* Remove the border on images inside links in IE 10. */ }
通過(guò)CSS樣式初始化,相信能解決不少常規(guī)的兼容性問(wèn)題,接下來(lái)再看看瀏覽器的私有屬性。
2. 瀏覽器私有屬性
我們經(jīng)常會(huì)在某個(gè)CSS的屬性前添加一些前綴,比如-webkit-,-moz- ,-ms-,這些就是瀏覽器的私有屬性。
為什么會(huì)出現(xiàn)私有屬性呢?這是因?yàn)橹贫℉TML和CSS標(biāo)準(zhǔn)的組織W3C動(dòng)作是很慢的。
通常,有W3C組織成員提出一個(gè)新屬性,比如說(shuō)圓角border-radius,大家都覺(jué)得好,但W3C制定標(biāo)準(zhǔn),要走很復(fù)雜的程序,審查等。而瀏覽器商市場(chǎng)推廣時(shí)間緊,如果一個(gè)屬性已經(jīng)夠成熟了,就會(huì)在瀏覽器中加入支持。
但是為避免日后W3C公布標(biāo)準(zhǔn)時(shí)有所變更,會(huì)加入一個(gè)私有前綴,比如-webkit-border-radius,通過(guò)這種方式來(lái)提前支持新屬性。等到日后W3C公布了標(biāo)準(zhǔn),border-radius的標(biāo)準(zhǔn)寫法確立之后,再讓新版的瀏覽器支持border-radius這種寫法。常用的前綴有:
- -moz代表firefox瀏覽器私有屬性
- -ms代表IE瀏覽器私有屬性
- -webkit代表chrome、safari私有屬性
- -o代表opera私有屬性
對(duì)于私有屬性的順序要注意,把標(biāo)準(zhǔn)寫法放到最后,兼容性寫法放到前面
-webkit-transform:rotate(-3deg); /*為Chrome/Safari*/ -moz-transform:rotate(-3deg); /*為Firefox*/ -ms-transform:rotate(-3deg); /*為IE*/ -o-transform:rotate(-3deg); /*為Opera*/ transform:rotate(-3deg);
每個(gè)CSS屬性寫這么一堆兼容性代碼,無(wú)疑是對(duì)生命最大的浪費(fèi),后面我們會(huì)講一下通過(guò)自動(dòng)化插件來(lái)處理這塊。
3. CSS hack
有時(shí)我們需要針對(duì)不同的瀏覽器或不同版本寫特定的CSS樣式,這種針對(duì)不同的瀏覽器/不同版本寫相應(yīng)的CSS code的過(guò)程,叫做CSS hack!
CSS hack的寫法大致歸納為3種:條件hack、屬性級(jí)hack、選擇符級(jí)hack。
條件hack
條件hack主要針對(duì)IE瀏覽器進(jìn)行一些特殊的設(shè)置
語(yǔ)法:
<!--[if <keywords>? IE <version>?]> 代碼塊,可以是html,css,js <![endif]-->
取值
keywords
if后面跟的條件共包含6種選擇方式:是否、大于、大于或等于、小于、小于或等于、非指定版本
是否:指定是否IE或IE某個(gè)版本。關(guān)鍵字:空
大于:選擇大于指定版本的IE版本。關(guān)鍵字:gt(greater than)
大于或等于:選擇大于或等于指定版本的IE版本。關(guān)鍵字:gte(greater than or equal)
小于:選擇小于指定版本的IE版本。關(guān)鍵字:lt(less than)
小于或等于:選擇小于或等于指定版本的IE版本。關(guān)鍵字:lte(less than or equal)
非指定版本:選擇除指定版本外的所有IE版本。關(guān)鍵字:!
version
IE瀏覽器版本,如6、7、8
IE10及以上版本已將條件注釋特性移除,使用時(shí)需注意。
舉例
<!--[if IE]> <p>你在非IE中將看不到我的身影</p> <![endif]--> <!--[if IE]> <style> .test{color:red;} </style> <![endif]--> <!--[if lt IE 9]> <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script> <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script> <![endif]-->
屬性級(jí)hack
屬性hack就是在CSS樣式屬性名前加上一些只有特定瀏覽器才能識(shí)別的hack前綴。
語(yǔ)法:
selector{<hack>?property:value<hack>?;}
取值:
:選擇IE6及以下。連接線(中劃線)(-)亦可使用,為了避免與某些帶中劃線的屬性混淆,所以使用下劃線()更為合適。
:選擇IE7及以下。諸如:(+)與(#)之類的均可使用,不過(guò)業(yè)界對(duì)()的認(rèn)知度更高
9:選擇IE6+
:選擇IE8+和Opera15以下的瀏覽器
舉例
如在不同的IE瀏覽器中設(shè)置不同的顏色,注意順序:低版本的兼容性寫法放到最后
.test { color: #0909; /* For IE8+ */ *color: #f00; /* For IE7 and earlier */ _color: #ff0; /* For IE6 and earlier */ }
選擇符級(jí)hack
選擇符級(jí)hack是針對(duì)一些頁(yè)面表現(xiàn)不一致或者需要特殊對(duì)待的瀏覽器,在CSS選擇器前加上一些只有某些特定瀏覽器才能識(shí)別的前綴進(jìn)行hack。
語(yǔ)法:
<hack> selector{ sRules }
取值:常見(jiàn)的選擇符級(jí)hack有
*html *前綴只對(duì)IE6生效
*+html *+前綴只對(duì)IE7生效
@media screen\9{...}只對(duì)IE6/7生效
@media \0screen {body { background: red; }}只對(duì)IE8有效
@media \0screen\,screen\9{body { background: blue; }}只對(duì)IE6/7/8有效
@media screen\0 {body { background: green; }} 只對(duì)IE8/9/10有效
@media screen and (min-width:0\0) {body { background: gray; }} 只對(duì)IE9/10有效
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {body { background: orange; }} 只對(duì)IE10有效
舉例:
* html .test { color: #090; } /* For IE6 and earlier */ * + html .test { color: #ff0; } /* For IE7 */
看到這里,我不得不為前端人員自豪,這也太難了吧~~
不過(guò)花大力氣解決這些兼容性問(wèn)題, 并不能給我們技術(shù)上帶來(lái)什么大的提升,無(wú)非是給各個(gè)瀏覽器廠商填坑罷了,隨著時(shí)間的流逝,這些技術(shù)的價(jià)值也會(huì)越來(lái)越小,怎么花最小的力氣解決css兼容性問(wèn)題,讓我們把更多的時(shí)間留給美好的生活,才是關(guān)鍵,好在有一些自動(dòng)化插件可以幫我們從繁重的兼容性處理中解脫處理。
4. 自動(dòng)化插件
Autoprefixer是一款自動(dòng)管理瀏覽器前綴的插件,它可以解析CSS文件并且添加瀏覽器前綴到CSS內(nèi)容里,使用Can I Use(caniuse網(wǎng)站)的數(shù)據(jù)來(lái)決定哪些前綴是需要的。
把Autoprefixer添加到資源構(gòu)建工具(例如Grunt)后,可以完全忘記有關(guān)CSS前綴的東西,只需按照最新的W3C規(guī)范來(lái)正常書(shū)寫CSS即可。如果項(xiàng)目需要支持舊版瀏覽器,可修改browsers參數(shù)設(shè)置 。
//我們編寫的代碼 div { transform: rotate(30deg); } // 自動(dòng)補(bǔ)全的代碼,具體補(bǔ)全哪些由要兼容的瀏覽器版本決定,可以自行設(shè)置 div { -ms-transform: rotate(30deg); -webkit-transform: rotate(30deg); -o-transform: rotate(30deg); -moz-transform: rotate(30deg); transform: rotate(30deg); }
目前webpack、gulp、grunt都有相應(yīng)的插件,如果還沒(méi)有使用,那就趕緊應(yīng)用到我們的項(xiàng)目中吧,別再讓CSS兼容性浪費(fèi)你的時(shí)間!
到此這篇關(guān)于解決CSS瀏覽器兼容性問(wèn)題的4種方案的文章就介紹到這了,更多相關(guān)CSS瀏覽器兼容性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
對(duì)常見(jiàn)的css屬性進(jìn)行瀏覽器兼容性總結(jié)(推薦)
這篇文章主要介紹了對(duì)常見(jiàn)的css屬性進(jìn)行瀏覽器兼容性總結(jié)(推薦)的相關(guān)資料,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-20CSS瀏覽器兼容性常見(jiàn)問(wèn)題總結(jié)大全(推薦)
這篇文章主要介紹了CSS瀏覽器兼容性常見(jiàn)問(wèn)題,ie各版本的瀏覽器的兼容情況做了詳細(xì)介紹,開(kāi)發(fā)中需要注意到的兼容性問(wèn)題大家可以注意一下,具體操作步驟大家可查看下文的詳2017-08-16- 本篇文章主要介紹了CSS3與頁(yè)面布局學(xué)習(xí)和總結(jié)——瀏覽器兼容與前端性能優(yōu)化 ,具有一定的參考價(jià)值,有需要的可以了解一下。2022-09-29
- 這篇文章主要介紹了各種瀏覽器下的CSS Hack兼容性寫法,CSS Hack大致可以分為內(nèi)部Hack和選擇器Hack以及HTML頭部引用Hack,需要的朋友可以參考下2016-03-14
CSS3中的Opacity多瀏覽器透明度兼容性問(wèn)題
用來(lái)設(shè)定元素透明度的 Opacity 是CSS 3里的一個(gè)屬性。當(dāng)然現(xiàn)在還只有少部分瀏覽器支持,不過(guò)各個(gè)瀏覽器都有自己的私有屬性來(lái)支持,其中包括老版本的Mozilla和Safari2015-11-09- 本文匯總了一些CSS的瀏覽器兼容性的hack,都是非常常用的,作為一個(gè)前端設(shè)計(jì)師經(jīng)常能夠用到,這里推薦給大家。2014-11-24
2013年五大主流瀏覽器 HTML5 與 CSS3 兼容性大比拼
這篇文章主要介紹了2013年五大主流瀏覽器 HTML5 和 CSS3 兼容性大比拼,需要的朋友可以參考下2014-11-18CSS對(duì)瀏覽器的兼容性性處理(IE7,6與Fireofx)
IE7,6與Fireofx的兼容性的處理實(shí)在是讓前端WEB開(kāi)發(fā)者為之而頭疼的事情,建議盡量用符合W3C標(biāo)準(zhǔn)格式寫代碼,本文搜集整理了一些于此相關(guān)方面的知識(shí),有此需求的各位朋友可以2013-08-21常見(jiàn)瀏覽器兼容性問(wèn)題與解決方案css篇
所謂的瀏覽器兼容性問(wèn)題,是指因?yàn)椴煌臑g覽器對(duì)同一段代碼有不同的解析,造成頁(yè)面顯示效果不統(tǒng)一的情況,瀏覽器的兼容性問(wèn)題是前端開(kāi)發(fā)人員經(jīng)常會(huì)碰到和必須要解決的問(wèn)題2013-08-11CSS實(shí)現(xiàn)兼容性的漸變背景(gradient)效果兼容眾多瀏覽器
本文就將展示如何實(shí)現(xiàn)兼容性的漸變背景效果。在眾多的瀏覽器中,目前不支持Opera瀏覽器。垂直漸變,起始顏色紅色,結(jié)束顏色藍(lán)色,結(jié)束的藍(lán)色的透明度是0.5,感興趣的朋友可2013-08-08