亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

瀏覽器兼容

標簽:
Html/CSS

1.什么是 CSS hack

  • 由于不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla Firefox,Chrome等,或者是同一厂商的浏览器的不同版本,如IE6和IE7,对CSS的解析认识不完全一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。

    • CSS Hack大致有3种表现形式,CSS属性前缀法、选择器前缀法以及IE条件注释法(即HTML头部引用if IE)Hack,实际项目中CSS Hack大部分是针对IE浏览器不同版本之间的表现差异而引入的。

    • 属性前缀法(即类内部Hack):例如 IE6能识别下划线""和星号" * ",IE7能识别星号" * ",但不能识别下划线"",IE6~IE10都认识"\9",但firefox前述三个都不能认识

    • 选择器前缀法(即选择器Hack)

    • IE条件注释法(即HTML条件注释Hack):针对所有IE(注:IE10+已经不再支持条件注释): ,针对IE6及以下版本:。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效

    • 这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能在不同的浏览器中也能得到我们想要的页面效果。

常见的兼容写法:

inline-block: >=ie8
min-width/min-height: >=ie8
:before,:after: >=ie8
div:hover: >=ie7
inline-block: >=ie8
background-size: >=ie9
圆角: >= ie9
阴影: >= ie9
动画/渐变: >= ie10

2.谈一谈浏览器兼容的思路

  1. 产品的接受人群,按照接受人群和使用各种浏览器的比例情况来确定是从效果优先还是基本功能优先

  2. 成本考虑,比如一些只有一般浏览器能接受的CSS效果,却非要放到IE67去做,确实是可以通过别的方式去模拟,但是这样就是将整个工程复杂化,这种情况也有可能会导致更多的BUG出现,工程时间延长,得不偿失

  3. 产品需要兼容什么浏览器,到什么版本,需要些什么效果

  4. 按照商讨规划,进行渐进增强和优雅降级的选择

  5. 根据兼容需求选择技术框架,如:

  • Bootstrap (>=ie8)

  • jQuery 1.~ (>=ie6), jQuery 2.~ (>=ie9)

  • Vue (>= ie9)   等等...

  1. 根据兼容需求选择一些兼容工具html5shiv.jsrespond.jscss resetnormalize.cssModernizrpostCSS

  2. 条件注释、CSS Hack、js 能力检测做一些修补。

3.列举5种以上浏览器兼容的写法

  • 条件注释 (conditional comment)

  • 是于HTML源码中被IE有条件解释的语句。条件注释可被用来向IE提供及隐藏代码。

<!--[if IE 6]> <p>You are using Internet Explorer 6.</p> <![endif]--> <!--[if !IE]><!--> <script>alert(1);</script> <!--<![endif]--> <!--[if IE 8]> <link href="ie8only.css" rel="stylesheet"> <![endif]-->     项目     范例               说明   !     [if !IE]              非IE   lt      [if lt IE 5.5]       小于IE 5.5   lte    [if lte IE 6]      小于等于IE6   gt      [if gt IE 5]       大于   IE5   gte    [if gte IE 7]      大于等于IE7    |      [if (IE 6)|(IE 7)]    IE6或者IE7

  • IE条件注释只支持到IE10以下不包括10

  • CSS属性前缀法

  • IE6能识别下划线""和星号" * ",IE7能识别星号" * ",但不能识别下划线"",IE6~IE10都认识"\9",但firefox前述三个都不能认识

  .box{     color: red;     _color: blue; /*ie6*/     *color: pink; /*ie67*/     color: yellow\9;  /*ie/edge 6-8*/     }

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消