整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          4種方案解決CSS瀏覽器兼容性問題

          擊右上方紅色按鈕關注“web秀”,讓你真正秀起來

          前言

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

          4種方案解決CSS瀏覽器兼容性問題

          為什么會有瀏覽器兼容性問題?

          還不是因為瀏覽器廠商太多了!

          Chrome,Frirefox,Safari,Edge,IE6,IE7,IE8,IE9...360安全瀏覽器,qq瀏覽器,世界之窗,TT,搜狗,opera,maxthon(傲游)……

          關鍵是不同廠商,甚至同一廠商不同版本,對同一段CSS的解析效果也不一致,這就導致了頁面顯示效果不統一,也就帶來了兼容性問題。

          多么希望Chrome能夠一統江湖啊~~

          4種方案解決CSS瀏覽器兼容性問題

          目前各瀏覽器市場份額

          瀏覽器這么多,我們也不可能每一個都要去兼容,對于用戶量一般的產品,把主流瀏覽器的適配做好,就已經很不錯啦。

          根據百度流量研究院提供的2018年8月至2019年2月的數據可以看出,Chrome占比46.28%,IE系仍然占有很大比重,任重而道遠啊~

          4種方案解決CSS瀏覽器兼容性問題

          CSS瀏覽器兼容性問題的解決思路和方案

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

          1. 瀏覽器CSS樣式初始化

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

          *{ 
           margin: 0; 
           padding: 0; 
          }
          

          關于瀏覽器CSS樣式初始化,經驗不豐富的話,可能也不知道該初始化什么,這里給大家推薦一個庫,Normalize.css,github star數量接近3.4萬,選取展示其中幾個樣式設置,如下

          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。

          條件hack

          條件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="http://cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script> 
           <script src="http://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script> 
          <![endif]-->
          

          屬性級hack

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

          • 語法:
           selector{<hack>?property:value<hack>?;}
          
          • 取值:

          :選擇IE6及以下。連接線(中劃線)(-)亦可使用,為了避免與某些帶中劃線的屬性混淆,所以使用下劃線()更為合適。

          :選擇IE7及以下。諸如:(+)與(#)之類的均可使用,不過業界對()的認知度更高

          :選擇IE6+

          >\0:選擇IE8+和Opera15以下的瀏覽器<:選擇IE8+和Opera15以下的瀏覽器

          • 舉例

          如在不同的IE瀏覽器中設置不同的顏色,注意順序:低版本的兼容性寫法放到最后

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

          選擇符級hack

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

          • 語法:
          <hack> selector{ sRules }
          
          • 取值:
          • 常見的選擇符級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兼容性浪費你的時間!

          公告

          喜歡小編的點擊關注,了解更多知識!

          端是一個讓人又愛又恨的職業,愛,是因為技術更新快,發展道路寬闊;恨的是需要學習、掌握的東西太多太多,永遠學不完,正如俗話說:活到老,學到老;但更讓人頭疼的是,還要面臨各種適配、兼容性問題。

          網上對適配、兼容性問題都有相關解答,但一直以來都是頭痛醫頭腳痛醫腳,沒有進行系統的梳理,整個思路和方向全是混亂的,所以最近整理了一份CSS瀏覽器兼容性的常見解決思路和方案,分享給大家,一起進步。

          瀏覽器兼容性問題原因

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

          各瀏覽器市場表現

          瀏覽器種類這么多,不可能每一個都要去兼容,所以對于用戶量一般的產品,把主流瀏覽器的適配做好,就已經很不錯啦。

          根據世界市場權威調查機構NetMarketShare公布的2018年10月各瀏覽器市場占有率,可以看出Chrome的占有率達到了66.43%。

          但根據百度流量研究院提供的2018年11月至2019年1月的數據可以看出,IE系仍然占有很大比重,兼容處理工作還需繼續。

          解決思路和方案(重點)

          這里我們不會去關注太多細節問題, 比如哪個css樣式需要我們去兼容等,主要從4個方面討論一下大的解決思路,分別是:瀏覽器CSS樣式初始化、瀏覽器私有屬性,CSS hack語法和自動化插件。

          1. CSS初始化

          前端的小伙伴一定遇到過因為默認樣式導致的錯亂問題,而且每個瀏覽器的css默認樣式不盡相同,所以最簡單有效的方式就是對其進行初始化(覆蓋默認樣式)。相信很多朋友也都寫過這樣的代碼,在所有CSS開始前,先把marin和padding都設為0。

          *{
              margin: 0;
              padding: 0;
          }

          關于瀏覽器CSS樣式初始化,經驗不豐富的話,尤其對于剛入門的小白,可能也不知道該初始化什么,這里推薦一個庫給大家,Normalize.css,github star數量接近4萬,自行選取展示其中幾個樣式設置,如下:

          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樣式初始化,已經解決了一大部分因為瀏覽器默認樣式導致的常規兼容性問題。接下來再看看瀏覽器的私有屬性。

          1. 瀏覽器私有屬性

          -webkit- ,-moz- ,-ms-等,這是我們經常在某個CSS屬性前添加的一些前綴,這些就是瀏覽器的私有屬性。

          說到私有屬性的出現也是因為制定HTML和CSS標準的組織W3C動作很慢。

          通常,有W3C組織成員提出一個新屬性,比如圓角border-radius,大家都覺得好,但W3C制定標準,要走很復雜的程序。而瀏覽器商市場推廣時間緊,如果一個屬性已經夠成熟了,就會在瀏覽器中加入支持。為避免日后W3C公布標準時有所變化,所以加入一個私有前綴,比如-webkit-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屬性寫這么一堆兼容性代碼,那無疑是對生命折磨,到后面就會講如何通過自動化插件來處理。

          1. CSS hack

          除了以上的默認樣式覆蓋及私有屬性添加,有時我們還需要針對不同的瀏覽器甚至不同版本編寫特定的CSS樣式,這一過程就叫做CSS hack!

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

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

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

          關鍵詞

          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版本。關鍵字:!

          版本

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

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

          selector{<hack>?property:value<hack>?;}
          • 取值:

          _:選擇IE6及以下。連接線(中劃線)(-)亦可使用,為了避免與某些帶中劃線的屬性混淆,所以使用下劃線(_)更為合適

          *:選擇IE7及以下。諸如:(+)與(#)之類的均可使用,不過業界對(*)的認知度更高

          :選擇IE6+

          >\0:選擇IE8+和Opera15以下的瀏覽器<:選擇IE8+和Opera15以下的瀏覽器

          • 舉個例子

          注意順序:低版本的兼容性寫法放到最后

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

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

          <hack> selector{ sRules }
          • 取值: 常見的選擇符級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兼容性問題。接下來,自動化插件可以上場了,我們終于可以從繁重的兼容性處理中解脫出來。

          1. 自動化插件

          Autoprefixer是一款自動管理瀏覽器前綴的插件,它可以解析CSS文件并且添加瀏覽器前綴到CSS內容里。

          把Autoprefixe添加到資源構建工具(如webpack)后,可以完全忘記前面的東西,只需按照最新的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兼容性浪費你的時間!


          受限于技術能力,如有問題可以在下方留言討論。想要了解更多前端技術、精彩熱文可關注同名公眾號“一郭鮮”。別著急,慢慢來,小郭與你一起成長

          mg{border:none} 解決IE瀏覽器有邊框問題, 而W3C瀏覽器無邊框問題

          選擇器的兼容性問題

          1 兒子選擇器>

          IE7開始兼容, IE6不兼容。

          div>p{
              color:red;
          }

          div的兒子p。和div的后代p的截然不同。

          能夠選擇:

          <div>
          <p>我是div的兒子</p>
          </div>

          不能選擇:

          <div>
          <ul>
          <li>
          <p>我是div的重孫子</p>
          </li>
          </ul>
          </div>

          2 序選擇器

          IE8開始兼容;IE6、7都不兼容

          選擇第1個li:

          <style type="text/css">
          ul li:first-child{
              color:red;
          }
          </style>

          選擇最后一個1i:

          ul li:last-child{
              color:blue;
          }

          由于瀏覽器的更新需要過程,所以現在如果公司還要求兼容IE6、7, 那么就要自己寫類名:

          <ul>
          <li class="first">項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li>項目</li>
          <li class="last">項目</li>
          </ul>

          用類選擇器來選擇第一個或者最后一個:

          ul li.first{
              color:red;
          }
          ul li.last{
              color:blue;
          }

          3 下一個兄弟選擇器

          IE7開始兼容, IE6不兼容。

          +表示選擇下一個兄弟

          <style type="text/css">
          h3+p{
          color:red;
          }
          </style>

          選擇上的是h3元素后面緊挨著的第一個兄弟。

          <h3>我是一個標題</h3>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <h3>我是一個標題</h3>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <h3>我是一個標題</h3>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <p>我是一個段落</p>
          <h3>我是一個標題</h3>



          選擇器:

          說IE6層面兼容的: 標簽選擇器、id選擇器、類選擇器、后代、交集選擇器、并集選擇器、通配符。

          p
          #box
          .spec
          div p
          div.spec
          div,p
          *

          IE7能夠兼容的:兒子選擇器、下一個兄弟選擇器

          div>p
          h3+p

          IE8能夠兼容的:序選擇器

          ul li:first-child
          ul li:last-child

          border-style兼容性問題

          比如, border:10px ridge red; 在chrome和firefox、IE中有細微差別:

          如果公司里面的設計師, 處女座的, 追求極高的頁面還原度, 那么不能使用css來制作邊框。

          就要用到圖片, 就要切圖了。所以, 比較穩定的就幾個:solid、dashed、dotted, 其他的邊框樣式盡量不要用。


          主站蜘蛛池模板: 武侠古典一区二区三区中文| 日韩爆乳一区二区无码| 国产午夜福利精品一区二区三区| 九九久久99综合一区二区| 精品无码人妻一区二区三区品 | 在线精品国产一区二区| 日本一区二区三区免费高清在线| 中文字幕精品一区二区| 久久一区二区三区免费播放| 中文字幕在线观看一区二区| 亚洲AV成人精品日韩一区18p| 日韩在线一区高清在线| 精品香蕉一区二区三区| 中文字幕在线一区二区在线| 无码AV天堂一区二区三区| 黑人大战亚洲人精品一区| 国产色情一区二区三区在线播放 | 亚洲一区精品伊人久久伊人| 最新中文字幕一区| 在线观看中文字幕一区| 久热国产精品视频一区二区三区| 成人精品一区二区户外勾搭野战 | 亚洲AV日韩精品一区二区三区| 爆乳无码AV一区二区三区| 在线视频一区二区三区四区| 精品免费国产一区二区| 在线观看国产一区亚洲bd| 国产一区精品视频| 国产vr一区二区在线观看| 国产精品乱码一区二区三区| 国产一区二区精品久久岳 | 日本一区二区三区四区视频| 国产一区韩国女主播| 国产乱码伦精品一区二区三区麻豆| 国产福利电影一区二区三区| 亚洲日韩精品无码一区二区三区| 亚洲AV日韩AV天堂一区二区三区| 亚洲一区二区三区在线| 国产精品一区二区资源| 国产日韩一区二区三免费高清| 亚洲AV色香蕉一区二区|