解決CSS瀏覽器兼容性問題的一些方案淺析


  前端是一個苦逼的職業,不僅因為技術更新快,而且要會的東西實在太多了,更讓人頭疼的是,還要面臨各種適配、兼容性問題。

  為什么會有瀏覽器兼容性問題。還不是因為瀏覽器廠商太多了。關鍵是不同廠商,甚至同一廠商不同版本,對同一段CSS的解析效果也不一致,這就導致了頁面顯示效果不統一,也就帶來了兼容性問題。

  市場上瀏覽器種類很多,不同瀏覽器的內核也不盡相同,所以各個瀏覽器對網頁的解析存在一定的差異。

  瀏覽器內核主要分為兩種,一是渲染引擎,另一個是js 引擎,內核更加傾向於說渲染引擎。常見的瀏覽器內核可以分四種:Trident、Gecko、Blink、Webkit

  我們暫且不去關注太多細節問題, 比如那個css樣式需要我們去兼容,而是想討論一下大的解決思路,主要包括4個方面,瀏覽器CSS樣式初始化、瀏覽器私有屬性,CSS hack語法和自動化插件。

1、瀏覽器CSS樣式初始化

  由於每個瀏覽器的css默認樣式不盡相同,所以最簡單有效的方式就是對其進行初始化,相信很多朋友都寫過這樣的代碼,在所有CSS開始前,先把marin和padding都設為0,以防不同瀏覽器的顯示效果不一樣。以及對一些常用的html元素進行一些初始化處理等等。

*{ margin: 0; padding: 0; }

  關於瀏覽器CSS樣式初始化,經驗不豐富的話,可能也不知道該初始化什么,這里給大家推薦一個庫,Normalize.css,github star數量接近3.4萬,選取展示其中幾個樣式設置,如下:也可以直接引入,<link href="https://cdn.bootcss.com/normalize/7.0.0/normalize.min.css" rel="stylesheet">

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. */ }

  通過CSS樣式初始化,相信能解決不少常規的兼容性問題,接下來再看看瀏覽器的私有屬性。

2、瀏覽器私有屬性

  我們經常會在某個CSS的屬性前添加一些前綴,比如-webkit-,-moz- ,-ms-,這些就是瀏覽器的私有屬性。為什么會出現私有屬性呢?這是因為制定HTML和CSS標准的組織W3C動作是很慢的。

  通常,有W3C組織成員提出一個新屬性,比如說圓角border-radius,大家都覺得好,但W3C制定標准,要走很復雜的程序,審查等。而瀏覽器商市場推廣時間緊,如果一個屬性已經夠成熟了,就會在瀏覽器中加入支持。但是為避免日后W3C公布標准時有所變更,會加入一個私有前綴,比如-webkit-border-radius,通過這種方式來提前支持新屬性。等到日后W3C公布了標准,border-radius的標准寫法確立之后,再讓新版的瀏覽器支持border-radius這種寫法。常用的前綴有:

  • -moz代表firefox瀏覽器私有屬性
  • -ms代表IE瀏覽器私有屬性
  • -webkit代表chrome、safari私有屬性
  • -o代表opera私有屬性

  對於私有屬性的順序要注意,把標准寫法放到最后,兼容性寫法放到前面

 -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屬性寫這么一堆兼容性代碼,無疑是對生命最大的浪費,后面我們會講一下通過自動化插件來處理這塊。

3、CSS hack

  有時我們需要針對不同的瀏覽器或不同版本寫特定的CSS樣式,這種針對不同的瀏覽器/不同版本寫相應的CSS code的過程,叫做CSS hack!

  CSS hack的寫法大致歸納為3種:條件hack、屬性級hack、選擇符級hack。

(1)條件hack主要針對IE瀏覽器進行一些特殊的設置

<!--[if <keywords>? IE <version>?]> 代碼塊,可以是html,css,js <![endif]-->

keywords

if后面跟的條件共包含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及以上版本已將條件注釋特性移除,使用時需注意。

<!--[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]-->

(2)屬性hack就是在CSS樣式屬性名前加上一些只有特定瀏覽器才能識別的hack前綴。

.test { color: #0909; /* For IE8+ */
 *color: #f00; /* For IE7 and earlier */ _color: #ff0; /* For IE6 and earlier */ }

(3)選擇符級hack是針對一些頁面表現不一致或者需要特殊對待的瀏覽器,在CSS選擇器前加上一些只有某些特定瀏覽器才能識別的前綴進行hack。

  常見的選擇符級hack有

*html *前綴只對IE6生效 *+html *+前綴只對IE7生效 @media screen\9{...}只對IE6/7生效 @media \0screen {body { background: red; }}只對IE8有效 @media \0screen\,screen\9{body { background: blue; }}只對IE6/7/8有效 @media screen\0 {body { background: green; }} 只對IE8/9/10有效 @media screen and (min-width:0\0) {body { background: gray; }} 只對IE9/10有效 @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {body { background: orange; }} 只對IE10有效

  比如

* html .test { color: #090; } /* For IE6 and earlier */ 
* + html .test { color: #ff0; } /* For IE7 */

  看到這里,我不得不為前端人員自豪,這也太難了吧~~不過花大力氣解決這些兼容性問題, 並不能給我們技術上帶來什么大的提升,無非是給各個瀏覽器廠商填坑罷了,隨着時間的流逝,這些技術的價值也會越來越小,怎么花最小的力氣解決css兼容性問題,讓我們把更多的時間留給美好的生活,才是關鍵,好在有一些自動化插件可以幫我們從繁重的兼容性處理中解脫處理。

4、自動化插件

  Autoprefixer是一款自動管理瀏覽器前綴的插件,它可以解析CSS文件並且添加瀏覽器前綴到CSS內容里,使用Can I Use(caniuse網站)的數據來決定哪些前綴是需要的。

  把Autoprefixer添加到資源構建工具(例如Grunt)后,可以完全忘記有關CSS前綴的東西,只需按照最新的W3C規范來正常書寫CSS即可。如果項目需要支持舊版瀏覽器,可修改browsers參數設置 。

//我們編寫的代碼 
div { transform: rotate(30deg); } // 自動補全的代碼,具體補全哪些由要兼容的瀏覽器版本決定,可以自行設置 
div { -ms-transform: rotate(30deg); -webkit-transform: rotate(30deg); -o-transform: rotate(30deg); -moz-transform: rotate(30deg); transform: rotate(30deg); }

  目前webpack、gulp、grunt都有相應的插件,如果還沒有使用,那就趕緊應用到我們的項目中吧,別再讓CSS兼容性浪費你的時間!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM