日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

浏览器兼容的方法

發(fā)布時間:2023/12/16 HTML 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 浏览器兼容的方法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

CSS瀏覽器兼容性的4個解決方案

Chrome,Frirefox,Safari,Edge,IE6,IE7,IE8,IE9…360安全瀏覽器,qq瀏覽器,世界之窗,TT,搜狗,opera,maxthon(傲游)……
不同廠商,甚至同一廠商不同版本,對同一段CSS的解析效果也不一致,這就導(dǎo)致了頁面顯示效果不統(tǒng)一,也就帶來了兼容性問題。

多么希望Chrome能夠一統(tǒng)江湖啊~~

目前各瀏覽器市場份額

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

根據(jù)世界市場權(quán)威調(diào)查機構(gòu)NetMarketShare公布的2018年10月各瀏覽器市場占有率,可以看出Chrome的占有率達到了66.43%,這絕對是一個振奮人心的好消息。

而根據(jù)百度流量研究院提供的2018年11月至2019年1月的數(shù)據(jù)可以看出,IE系仍然占有很大比重,任重而道遠(yuǎn)啊~

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

今天,不想去關(guān)注太多細(xì)節(jié)問題, 比如那個css樣式需要我們?nèi)ゼ嫒?#xff0c;而是想討論一下大的解決思路,主要包括4個方面,瀏覽器CSS樣式初始化、瀏覽器私有屬性,CSS hack語法和自動化插件。

1. 瀏覽器CSS樣式初始化

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

*{margin: 0;padding: 0; }

關(guān)于瀏覽器CSS樣式初始化,經(jīng)驗不豐富的話,可能也不知道該初始化什么,這里給大家推薦一個庫,Normalize.css,github star數(shù)量接近4萬,選取展示其中幾個樣式設(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. */ }

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

2. 瀏覽器私有屬性

我們經(jīng)常會在某個CSS的屬性前添加一些前綴,比如-webkit- ,-moz- ,-ms-,這些就是瀏覽器的私有屬性。

為什么會出現(xiàn)私有屬性呢?這是因為制定HTML和CSS標(biāo)準(zhǔn)的組織W3C動作是很慢的。

通常,有W3C組織成員提出一個新屬性,比如說圓角border-radius,大家都覺得好,但W3C制定標(biāo)準(zhǔn),要走很復(fù)雜的程序,審查等。而瀏覽器商市場推廣時間緊,如果一個屬性已經(jīng)夠成熟了,就會在瀏覽器中加入支持。

但是為避免日后W3C公布標(biāo)準(zhǔn)時有所變更,會加入一個私有前綴,比如-webkit-border-radius,通過這種方式來提前支持新屬性。等到日后W3C公布了標(biāo)準(zhǔn),border-radius的標(biāo)準(zhǔn)寫法確立之后,再讓新版的瀏覽器支持border-radius這種寫法。常用的前綴有:

-moz代表firefox瀏覽器私有屬性
-ms代表IE瀏覽器私有屬性
-webkit代表chrome、safari私有屬性
-o代表opera私有屬性
對于私有屬性的順序要注意,把標(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);

每個CSS屬性寫這么一堆兼容性代碼,無疑是對生命最大的浪費,后面我們會講一下通過自動化插件來處理這塊。

3. CSS hack

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

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

條件hack

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

語法:

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

取值

keywords

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

是否:指定是否IE或IE某個版本。關(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及以上版本已將條件注釋特性移除,使用時需注意。

舉例

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

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

語法:

selector{<hack>?property:value<hack>?;}

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

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

9:選擇IE6+

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

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

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

選擇符級hack

選擇符級hack是針對一些頁面表現(xiàn)不一致或者需要特殊對待的瀏覽器,在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 */

看到這里,我不得不為前端人員自豪,這也太難了吧~~

不過花大力氣解決這些兼容性問題, 并不能給我們技術(shù)上帶來什么大的提升,無非是給各個瀏覽器廠商填坑罷了,隨著時間的流逝,這些技術(shù)的價值也會越來越小,怎么花最小的力氣解決css兼容性問題,讓我們把更多的時間留給美好的生活,才是關(guān)鍵,好在有一些自動化插件可以幫我們從繁重的兼容性處理中解脫處理。

4. 自動化插件

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

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

div {transform: rotate(30deg); }//自動補全的代碼,具體補全哪些由要兼容的瀏覽器版本決定,可以自行設(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)的插件,如果還沒有使用,那就趕緊應(yīng)用到我們的項目中吧,別再讓CSS兼容性浪費你的時間!

總結(jié)

以上是生活随笔為你收集整理的浏览器兼容的方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。