天呢,我和一個關注我的朋友聊啦聊,他是個在自學前端的朋友,和我說啦下對瀏覽器兼容的問題
小七前端
以及js加載的順序為什么有的在head里有的在body后,非常感謝這個朋友的提議。話不多說,今天小
七和大家分享下我對這些的理解。
1:瀏覽器默認的間距問題。
解決辦法:引入一個reset的文件,這個文件是一個默認css重置文件,這個百度上可以搜到下載。
2:div被擠到下一行。
解決辦法:可以把float的樣式設置為行內標簽(display:inline);
3:圖片會有默認間距
解決辦法:把img加一個浮動標簽。
4:解決ie版本的樣式問題,可以用到hack寫法
color:red; /* 所有瀏覽器可識別*/
_color:red; /* 僅IE6 識別 */
*color:red; /* IE6、IE7 識別 */
+color:red; /* IE6、IE7 識別 */
*+color:red; /* IE6、IE7 識別 */
[color:red; /* IE6、IE7 識別 */
color:red; /* IE6、IE7、IE8、IE9 識別 */
color:red>color:red\0; /* IE8、IE9 識別*/<; /* IE8、IE9 識別*/
color:red>color:red\9\0; /* 僅IE9識別 */<; /* 僅IE9識別 */
color:red >color:red \0; /* 僅IE9識別 */<; /* 僅IE9識別 */
color:red!important; /* IE6 不識別!important 有危險*/
前面或后面的符合或數字或\表示的是指在某個版本下的寫法,就是其他版本會不起作用,這個可以針對你在那個IE版本調什么樣式。
5:透明度屬性的兼容問題,ie和其他瀏覽器是不一樣的
解決辦法:標準瀏覽器:opacity: 0.5; IE:filter: alpha(opacity = 50);
6:無法定義1px左右高度的容器
IE6下這個問題是因為默認的行高造成的,解決的技巧也有很多:
解決辦法:overflow:hidden zoom:0.08 line-height:1px
當然還有很多問題,但我也記不太清除啦 比如說IE6的階梯浮動,但現在IE6基本上公司已經不考慮啦。
我先大概和大家說一下我避免瀏覽器兼容的要點,這個只是我的辦法。
第一:布局的時候一定要清清楚楚的先在大腦里構造好布局你要什么樣的布局,先想好在做。
第二:div閉合標簽問題,一個div有起有尾,千萬不能丟失或者遺漏,有可能會出現大問題,而且并不好找。
第三:浮動的時候注意 如果浮動完 必須清楚浮動,要么之后的元素會頂上去。
還有做網站有的為什么拖動瀏覽器窗口不會變亂 這點寫法也要注意一下。
比如一個div里面包含元素 這個div盡量不要去設置寬度 用padding或者margin去撐開,著樣你不論怎么拖動瀏覽器窗口都不會亂,但最小寬度一定要設置一個。
做移動端網站注意的:元素不需要高度,不需要高度,不需要高度,重要的事情說三遍。很多元素都不是你能決定里面會有多少東西,
是通過后臺返回的數據判斷的,所以你做的只需要給他加一個paadding 或者margin 千萬不要加高度。
然后說一個小技巧 后臺遍歷li的時候,如果li有下劃線,但是加載出來的數據都有怎么去把最后一條的li下劃線去掉,可以用到css的last選擇器:用法是ul:li:last-child{};
小七前端
js加載順序的問題。
瀏覽器解析html文件是從上到下的,如果把js引入放在head里面,那瀏覽器會先把js文件解析完畢然后在去解析body里面的東西,所以很可能獲取元素內容的時候會未定義。
可能很多人會說 我沒有出現過這種問題,那是因為你寫js的時候加入啦 windows.onload=function(){},這個殼的意思是指當全部的html解析完成之后在去解析js里的代碼。
我建議大家把js引入的時候放在body之后,因為如果js文件比較大的話,瀏覽器會先去解析js文件,會影響網頁的加載速度。
今天小七和大家分享的就這么多,雙十二剛過,大家剁手沒。
謝謝關注,嘿嘿。
端是一個讓人又愛又恨的職業,愛,是因為技術更新快,發展道路寬闊;恨的是需要學習、掌握的東西太多太多,永遠學不完,正如俗話說:活到老,學到老;但更讓人頭疼的是,還要面臨各種適配、兼容性問題。
網上對適配、兼容性問題都有相關解答,但一直以來都是頭痛醫頭腳痛醫腳,沒有進行系統的梳理,整個思路和方向全是混亂的,所以最近整理了一份CSS瀏覽器兼容性的常見解決思路和方案,分享給大家,一起進步。
其實就是一句話,瀏覽器廠商太多。關鍵是不同廠商,甚至同一廠商不同版本,對同一段CSS的解析效果也不一致,這就導致了頁面顯示效果不統一,也就帶來了兼容性問題。
瀏覽器種類這么多,不可能每一個都要去兼容,所以對于用戶量一般的產品,把主流瀏覽器的適配做好,就已經很不錯啦。
根據世界市場權威調查機構NetMarketShare公布的2018年10月各瀏覽器市場占有率,可以看出Chrome的占有率達到了66.43%。
但根據百度流量研究院提供的2018年11月至2019年1月的數據可以看出,IE系仍然占有很大比重,兼容處理工作還需繼續。
這里我們不會去關注太多細節問題, 比如哪個css樣式需要我們去兼容等,主要從4個方面討論一下大的解決思路,分別是:瀏覽器CSS樣式初始化、瀏覽器私有屬性,CSS hack語法和自動化插件。
前端的小伙伴一定遇到過因為默認樣式導致的錯亂問題,而且每個瀏覽器的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樣式初始化,已經解決了一大部分因為瀏覽器默認樣式導致的常規兼容性問題。接下來再看看瀏覽器的私有屬性。
-webkit- ,-moz- ,-ms-等,這是我們經常在某個CSS屬性前添加的一些前綴,這些就是瀏覽器的私有屬性。
說到私有屬性的出現也是因為制定HTML和CSS標準的組織W3C動作很慢。
通常,有W3C組織成員提出一個新屬性,比如圓角border-radius,大家都覺得好,但W3C制定標準,要走很復雜的程序。而瀏覽器商市場推廣時間緊,如果一個屬性已經夠成熟了,就會在瀏覽器中加入支持。為避免日后W3C公布標準時有所變化,所以加入一個私有前綴,比如-webkit-border-radius,常用的前綴有:
對于書寫順序一定要注意,兼容性寫法放到前面,把標準寫法放到最后
-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樣式,這一過程就叫做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 }
*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兼容性問題。接下來,自動化插件可以上場了,我們終于可以從繁重的兼容性處理中解脫出來。
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兼容性浪費你的時間!
受限于技術能力,如有問題可以在下方留言討論。想要了解更多前端技術、精彩熱文可關注同名公眾號“一郭鮮”。別著急,慢慢來,小郭與你一起成長
覽器兼容性問題在前端開發中是一個非常普遍且重要的挑戰。不同的瀏覽器對CSS、JavaScript和HTML的解析方式存在差異,這可能導致頁面在不同瀏覽器上顯示效果不一致或功能無法正常運行。在本文中,我們將深入探討瀏覽器兼容性問題,并提供一系列解決方案,幫助開發人員更好地應對這些挑戰。
首先,讓我們來了解一下瀏覽器兼容性問題的具體表現以及對前端開發的影響。隨著互聯網的不斷發展,用戶使用的瀏覽器種類也日益多樣化,例如Chrome、Firefox、Safari、Edge等,每種瀏覽器都有自己獨特的特性和實現方式。這就為前端開發引入了不小的挑戰,因為我們需要確保網頁在各種不同的瀏覽器上都能夠正確顯示并且功能正常。
在面對瀏覽器兼容性問題時,開發人員需要考慮一系列的解決方案。首先,針對CSS樣式兼容性問題,我們可以通過使用CSS前綴來提高兼容性。不同瀏覽器對某些CSS屬性的支持程度不同,例如-webkit-box-shadow和-moz-box-shadow等,因此我們可以為每個瀏覽器提供不同的屬性值,以確保它們在所有主流瀏覽器上都可以正常工作。此外,使用CSS reset或normalize.css可以消除瀏覽器默認樣式的差異,使網頁在不同瀏覽器上顯示效果更加一致。
其次,對于JavaScript API兼容性問題,特性檢測是一種非常有效的解決方案。特性檢測可以用于檢測瀏覽器是否支持某個JavaScript API或屬性,從而為不同瀏覽器提供備用方案或polyfill來實現兼容性。另外,使用Babel等工具可以將新的JavaScript語法轉換為舊版本以增強兼容性,從而確保我們的代碼在不同瀏覽器中都能夠運行。
在處理HTML結構兼容性問題時,遵循標準的HTML語義化結構是非常重要的。標準的HTML語義化結構可以使我們編寫可讀性高、易于維護的HTML代碼,并確保頁面在不同瀏覽器上正確地呈現。此外,避免使用過時的HTML標記和屬性也能夠幫助我們避免頁面在不同瀏覽器上出現兼容性問題。
針對響應式設計兼容性問題,我們可以使用CSS媒體查詢來編寫不同的樣式,以確保頁面在不同設備上都能夠正確顯示。另外,我們還需要仔細考慮頁面的布局和響應式設計,以確保頁面能夠適應不同的顯示環境。
最后,跨瀏覽器測試是檢測和解決瀏覽器兼容性問題的重要步驟。通過使用像Can I Use、BrowserStack、CrossBrowserTesting等工具進行跨瀏覽器測試,我們可以在多個瀏覽器上測試Web應用程序,以確保頁面在各種主流瀏覽器上都能夠正確顯示和運行。
總的來說,解決瀏覽器兼容性問題是前端開發過程中非常重要的任務之一。通過使用一系列技術和工具,開發人員可以確保他們的Web應用程序在不同瀏覽器上以相同的方式呈現,從而提高用戶體驗、網站的可訪問性,并為Web開發人員提供更好的開發體驗。通過不斷學習和實踐,我們可以更好地應對瀏覽器兼容性問題,為用戶提供更優秀的Web體驗。
*請認真填寫需求信息,我們會在24小時內與您取得聯系。