操屁眼的视频在线免费看,日本在线综合一区二区,久久在线观看免费视频,欧美日韩精品久久综

新聞資訊

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

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

    瀏覽器兼容性問題原因

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

    各瀏覽器市場表現

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

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

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

    解決思路和方案(重點)

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

    CSS初始化

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

    *{
        margin: 0;
        padding: 0;
    }

    關于瀏覽器CSS樣式初始化,經驗不豐富的話,尤其對于剛入門的小白,可能也不知道該初始化什么,這里推薦一個庫給大家,.css, 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樣式初始化,已經解決了一大部分因為瀏覽器默認樣式導致的常規兼容性問題。接下來再看看瀏覽器的私有屬性。

    瀏覽器私有屬性

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

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

    通常,有W3C組織成員提出一個新屬性,比如圓角-,大家都覺得好,但W3C制定標準,要走很復雜的程序。而瀏覽器商市場推廣時間緊,如果一個屬性已經夠成熟了,就會在瀏覽器中加入支持。為避免日后W3C公布標準時有所變化,所以加入一個私有前綴,比如---,常用的前綴有:

    對于書寫順序一定要注意,兼容性寫法放到前面,把標準寫法放到最后

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

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

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

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

    關鍵詞

    if后面跟的條件共包含6種選擇方式:是否、大于、大于或等于、小于、小于或等于、非指定版本

    是否:指定是否IE或IE某個版本。關鍵字:空

    大于:選擇大于指定版本的IE版本。關鍵字:gt( than)

    大于或等于:選擇大于或等于指定版本的IE版本。關鍵字:gte( than or equal)

    小于:選擇小于指定版本的IE版本。關鍵字:lt(less than)

    小于或等于:選擇小于或等于指定版本的IE版本。關鍵字:lte(less than or equal)

    非指定版本:選擇除指定版本外的所有IE版本。關鍵字:!

    版本

    IE瀏覽器版本,如6、7、8,但IE10及以上版本已將條件注釋特性移除,使用時需注意。

    
    

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

    selector{?property:value?;}

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

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

    \9:選擇IE6+

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

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

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

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

     selector{ sRules }

    *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兼容性問題。接下來,自動化插件可以上場了,我們終于可以從繁重的兼容性處理中解脫出來。

    自動化插件

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

    把添加到資源構建工具(如)后,可以完全忘記前面的東西,只需按照最新的W3C規范來正常書寫CSS,剩下的工作交給插件來處理。另外,如果項目需要支持舊版瀏覽器,可修改參數設置。

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

    目前、gulp、grunt都有相應的插件,趕快行動起來,別再讓CSS兼容性浪費你的時間!

網站首頁   |    關于我們   |    公司新聞   |    產品方案   |    用戶案例   |    售后服務   |    合作伙伴   |    人才招聘   |   

友情鏈接: 餐飲加盟

地址:北京市海淀區    電話:010-     郵箱:@126.com

備案號:冀ICP備2024067069號-3 北京科技有限公司版權所有