淺談瀏覽器的兼容性到底怎么樣?


淺談瀏覽器的兼容性到底怎么樣?

我就說說自己的看法??,矚g緣那脛剛?。
瀏覽器就是2大派系,一個是其他瀏覽器,一個是IE(這TM就是個異端) 。
瀏覽器的區別主要就是4個部分了
1.對于各種元素margin和padding的默認值不一樣 。
2.ie和其他瀏覽器的css盒模型不一樣,ie的width和height包括了padding和border,而其他瀏覽器的css盒模型才是標準的盒模型,height和width是指content的寬和高 。
3.對于css3的支持程度不一樣 。
4.對于ES5和ES6的支持程度不一樣 。
5.html5的標簽 。
6.css3的媒體查詢
對應解決方法:
1.引入normalize.css,可以統一各種元素的margin和padding等屬性 。
2.css3的一個屬性box-sizing可以定義該元素以哪種盒模型進行渲染 。content-box為標準盒模型,border-box為IE的盒模型 。
3.引入PIE.htc或者其他的能夠使IE兼容css3的文件,但是都有局限性,無法完全兼容css3的所有特性,具體的請自行度娘 。
【淺談瀏覽器的兼容性到底怎么樣?】4.IE8是部分支持es5的,可以引入es5-shim.js 。ps:不小心看到了es5-sham查了下他們的區別 。es5-shim就是實現的是原生的ES5,而sham中實現了一些新的API 。這樣就可以使用es6編程再利用babel編譯了 。
5.引入html5shiv.js , 可以讓ie支持html5的標簽 。
6.可以引入Respond.js,使ie可以使用媒體查詢 , 實現響應式開發 。


相關經驗推薦