区分浏览器不同版本的css以及html写法

对于不同浏览器执行不同的css是目前解决不同浏览器以及浏览器不同版本的一种方法,而怎么样针对以上的状况来写css或者是html呢?请看下文:

一、CSS的写法

1. 区别IE和非IE浏览器

代码如下:

#tip {

background:blue;  /*非IE 背景藍色*/

background:red \9;  /*IE6、IE7、IE8背景紅色*/

}

#tip { background:blue; /*非IE 背景藍色*/ background:red \9; /*IE6、IE7、IE8背景紅色*/ }

 


2. 区别IE6,IE7,IE8,FF

【区别符号】:「\9」、「*」、「_」
【示例】:

 

  1. #tip {
  2. background:blue; /*Firefox 背景变蓝色*/
  3. background:red \9; /*IE8 背景变红色*/
  4. *background:black; /*IE7 背景变黑色*/
  5. _background:orange; /*IE6 背景变橘色*/
  6. }

#tip { background:blue; /*Firefox 背景变蓝色*/ background:red \9; /*IE8 背景变红色*/ *background:black; /*IE7 背景变黑色*/ _background:orange; /*IE6 背景变橘色*/ }

 

【说明】:因为IE系列浏览器可读「\9」,而IE6和IE7可读「*」(米字号),另外IE6可辨识「_」(底线),因此可以依照顺序写下来,就会让浏览器正确的读取到自己看得懂得CSS语法,所以就可以有效区分IE各版本和非IE浏览器(像是Firefox、Opera、Google Chrome、Safari等)。


3. 区别IE6、IE7、Firefox (方法 1)

【区别符号】:「*」、「_」
【示例】:

 

  1. #tip {
  2. background:blue; /*Firefox背景变蓝色*/
  3. *background:black; /*IE7 背景变黑色*/
  4. _background:orange; /*IE6 背景变橘色*/
  5. }

【说明】:IE7和IE6可读「*」(米字号),IE6又可以读「_」(底线),但是IE7却无法读取「_」,至于Firefox(非IE浏览器)则完全无法辨识「*」和「_」,因此就可以透过这样的差异性来区分IE6、IE7、Firefox

4.区别IE6、IE7、Firefox (方法 2)

【区别符号】:「*」、「!important」
【示例】:

#tip {    background:blue; /*Firefox 背景变蓝色*/    *background:green !important; /*IE7 背景变绿色*/    *background:orange; /*IE6 背景变橘色*/     }

#tip { background:blue; /*Firefox 背景变蓝色*/*background:green !important; /*IE7 背景变绿色*/ *background:orange; /*IE6 背景变橘色*/ }

 

【说明】:IE7可以辨识「*」和「!important」,但是IE6只可以辨识「*」,却无法辨识「!important」,至于Firefox可以读取「!important」但不能辨识「*」因此可以透过这样的差异来有效区隔IE6、IE7、Firefox。
5.区别IE7、Firefox

【区别符号】:「*」、「!important」
【示例】:

#tip {    background:blue; /*Firefox 背景变蓝色*/    *background:green !important; /*IE7 背景变绿色*/    }

#tip {background:blue; /*Firefox 背景变蓝色*/ *background:green !important; /*IE7 背景变绿色*/}

 

【说明】:因为Firefox可以辨识「!important」但却无法辨识「*」,而IE7则可以同时看懂「*」、「!important」,因此可以两个辨识符号来区隔IE7和Firefox。 6.区别IE6、IE7 (方法 1)

【区别符号】:「*」、「_」
【示例】:

#tip {    *background:black; /*IE7 背景变黑色*/    _background:orange; /*IE6 背景变橘色*/    }

#tip { *background:black; /*IE7 背景变黑色*/_background:orange; /*IE6 背景变橘色*/}

 

【说明】:IE7和IE6都可以辨识「*」(米字号),但IE6可以辨识「_」(底线),IE7却无法辨识,透过IE7无法读取「_」的特性就能轻鬆区隔IE6和IE7之间的差异。 7.区别IE6、IE7 (方法 2)

【区别符号】:「!important」
【示例】:

#tip {    background:black !important; /*IE7 背景变黑色*/    background:orange; /*IE6 背景变橘色*/    }

#tip { background:black !important; /*IE7 背景变黑色*/background:orange; /*IE6 背景变橘色*/ }

 

【说明】:因为IE7可读取「!important;」但IE6却不行,而CSS的读取步骤是从上到下,因此IE6读取时因无法辨识「!important」而直接跳到下一行读取CSS,所以背景色会呈现橘色。 8.区别IE6、Firefox
【区别符号】:「_」
【示例】:

#tip {    background:black; /*Firefox 背景变黑色*/    _background:orange; /*IE6 背景变橘色*/    }

#tip { background:black; /*Firefox 背景变黑色*/_background:orange; /*IE6 背景变橘色*/}

 

【说明】:因为IE6可以辨识「_」(底线),但是Firefox却不行,因此可以透过这样的差异来区隔Firefox和IE6,有效达成CSS hack。
二、HTML写法

<!–[if !IE]><!–>  除IE外都可识别 <!–<![endif]–>  <!–[if IE]> 所有的IE可识别 <![endif]–>  <!–[if IE 5.0]> 只有IE5.0可以识别 <![endif]–>  <!–[if IE 5]> 仅IE5.0与IE5.5可以识别 <![endif]–>  <!–[if gte IE 5.0]> IE5.0以及IE5.0以上版本都可以识别 <![endif]–>  <!–[if IE 6]> 仅IE6可识别 <![endif]–>  <!–[if lte IE 6]> IE6以及IE6以下版本可识别 <![endif]–>  <!–[if gte IE 6]> IE6以及IE6以上版本可识别 <![endif]–>  <!–[if IE 7]> 仅IE7可识别 <![endif]–>  <!–[if lte IE 7]> IE7以及IE7以下版本可识别 <![endif]–>  <!–[if gte IE 7]> IE7以及IE7以上版本可识别 <![endif]–>

 

上面代码的部分解释:
gt=great than 大于
lt=less than 小于
lte=less than or Equal 大于或等于
gte great than or equal 小于或等于

未经允许不得转载:面包頭 » 区分浏览器不同版本的css以及html写法

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址