html兼容IE中的<!--[if IE]--><!--[endif]-->说明
2016-09-29 10:58
309 查看
在进行网页的学习和应用过程中,网页对浏览器的兼容性是经常接触到的一个问题。IE占据浏览器市场的大半江山,此外还有Firefox、Opera等。需要对这些浏览器进行兼容。常用的CSS
HACK,或者JS脚本控制等。CSS HACK运用得比较多,但是不同浏览器支持的HACK都不一样,会给制作者和浏览代码的时候带来很多困难。JS脚本控制除了浏览器兼容问题,对于制作者也有不小的要求。因此,在进行比较复杂的浏览器兼容问题的,判断浏览器类型就成了一个比较好的方法了,我们可以根据不同浏览器书写不同的HTML代码,做到兼容。<!--[if
IE]> <![endif]-->就可以实现这样的简单功能。当然它主要针对IE而言。因为IE可以识别,但是别的浏览器却会认为这只是一个注释。
就IE本身来说,常用的有IE6,IE7,IE8,以及刚刚发布IE9。因IE版本的升级更替,目前浏览者使用的主要停留在IE6和IE7这两个版本中。而这2个版本对于我们制作的WEB标准网页(XHTML+CSS)解析执行的显示状况不尽相同。并 且,其他非IE浏览器与IE对某些CSS解析也不一样。所以,想做到兼容,就得通过IE浏览器中的专有条件注释可有针对性的进行相关属性的定义。下面就介绍一下IE里面的条件注释(<!--[if
IE]> <![endif]-->).
条件注释只能用于Explorer 5+ Windows(以下简称IE)(条件注释从IE5开始被支持)。如果你安装了多个IE,条件注释(Conditional
comments)将会以最高版本的IE为标准(目前为IE 7).简单说,
条件注释就是一些if判断,但这些判断不是在脚本里执行的,而是直接在html代码里执行的,比如: <!--[if
IE]>
这里是IE里面正常的html代码
<![endif]-->
它的如下特点:
1,条件注释的基本结构和HTML的注释(<!-- -->)是一样的。因此IE以外的浏览器将会把它们看作是普通的注释而完全忽略它们。
2,IE将会根据if条件来判断是否如解析普通的页面内容一样解析条件注释里的内容。
3,条件注释使用的是HTML的注释结构,因此他们只能使用在HTML文件里,而不能在CSS文件中使用。
例如,我们可使用如下代码检测当前IE浏览器的版本(注意:只是针对IE)
<!--[if IE]>
<h1>您正在使用IE浏览器</h1>
<!--[if IE 5.0]>
<h2>版本 5.0</h2>
<![endif]-->
<!--[if IE 6]>
<h2>版本 6</h2>
<![endif]-->
<!--[if IE 7]>
<h2>版本 7</h2>
<![endif]-->
<![endif]-->
那如果当前的浏览器是IE,但版本比IE5还低,该怎么办呢,可以使用<!--[if
ls IE 5]>,当然,根据条件注释只能在IE5+的环境之下,所以<!--[if ls IE 5]>根本不会被执行。当然这种情况现在看来已经很少了。
在具体运用方面,很多时候对于不同浏览器我们需要调用不同的样式表,那么这个条件注释就有可以帮助我们了:
<!-- 默认先调用css.css样式表 -->
<link rel="stylesheet" type="text/css" href="css.css" />
<!--[if IE 7]>
<!-- 如果IE浏览器版是7,调用IE7.css样式表 -->
<link rel="stylesheet" type="text/css" href="IE7.css" />
<![endif]-->
<!--[if lte IE 6]>
<!-- 如果IE浏览器版本小于等于6,调用IE.css样式表 -->
<link rel="stylesheet" type="text/css" href="IE.css" />
<![endif]-->
这其中就区分了IE7和IE6向下的浏览器对CSS的执行,达到兼容的目的。同时,首行默认的css.css还能与其他非IE浏览器实现兼容。正常就是默认的样式,对IE浏览器需要特殊处理的,才进行条件注释。
这里需要注意的是:默认的CSS样式应该位于HTML文档的首行,进行条件注释判断的所有内容必须位于该默认样式之后。
所以,这种方法可以直接根据浏览器来执行相应代码,比单独的CSS HACK要强大许多,这也是我们网站项目中常用的方法。
HACK,或者JS脚本控制等。CSS HACK运用得比较多,但是不同浏览器支持的HACK都不一样,会给制作者和浏览代码的时候带来很多困难。JS脚本控制除了浏览器兼容问题,对于制作者也有不小的要求。因此,在进行比较复杂的浏览器兼容问题的,判断浏览器类型就成了一个比较好的方法了,我们可以根据不同浏览器书写不同的HTML代码,做到兼容。<!--[if
IE]> <![endif]-->就可以实现这样的简单功能。当然它主要针对IE而言。因为IE可以识别,但是别的浏览器却会认为这只是一个注释。
就IE本身来说,常用的有IE6,IE7,IE8,以及刚刚发布IE9。因IE版本的升级更替,目前浏览者使用的主要停留在IE6和IE7这两个版本中。而这2个版本对于我们制作的WEB标准网页(XHTML+CSS)解析执行的显示状况不尽相同。并 且,其他非IE浏览器与IE对某些CSS解析也不一样。所以,想做到兼容,就得通过IE浏览器中的专有条件注释可有针对性的进行相关属性的定义。下面就介绍一下IE里面的条件注释(<!--[if
IE]> <![endif]-->).
条件注释只能用于Explorer 5+ Windows(以下简称IE)(条件注释从IE5开始被支持)。如果你安装了多个IE,条件注释(Conditional
comments)将会以最高版本的IE为标准(目前为IE 7).简单说,
条件注释就是一些if判断,但这些判断不是在脚本里执行的,而是直接在html代码里执行的,比如: <!--[if
IE]>
这里是IE里面正常的html代码
<![endif]-->
它的如下特点:
1,条件注释的基本结构和HTML的注释(<!-- -->)是一样的。因此IE以外的浏览器将会把它们看作是普通的注释而完全忽略它们。
2,IE将会根据if条件来判断是否如解析普通的页面内容一样解析条件注释里的内容。
3,条件注释使用的是HTML的注释结构,因此他们只能使用在HTML文件里,而不能在CSS文件中使用。
例如,我们可使用如下代码检测当前IE浏览器的版本(注意:只是针对IE)
<!--[if IE]>
<h1>您正在使用IE浏览器</h1>
<!--[if IE 5.0]>
<h2>版本 5.0</h2>
<![endif]-->
<!--[if IE 6]>
<h2>版本 6</h2>
<![endif]-->
<!--[if IE 7]>
<h2>版本 7</h2>
<![endif]-->
<![endif]-->
那如果当前的浏览器是IE,但版本比IE5还低,该怎么办呢,可以使用<!--[if
ls IE 5]>,当然,根据条件注释只能在IE5+的环境之下,所以<!--[if ls IE 5]>根本不会被执行。当然这种情况现在看来已经很少了。
在具体运用方面,很多时候对于不同浏览器我们需要调用不同的样式表,那么这个条件注释就有可以帮助我们了:
<!-- 默认先调用css.css样式表 -->
<link rel="stylesheet" type="text/css" href="css.css" />
<!--[if IE 7]>
<!-- 如果IE浏览器版是7,调用IE7.css样式表 -->
<link rel="stylesheet" type="text/css" href="IE7.css" />
<![endif]-->
<!--[if lte IE 6]>
<!-- 如果IE浏览器版本小于等于6,调用IE.css样式表 -->
<link rel="stylesheet" type="text/css" href="IE.css" />
<![endif]-->
这其中就区分了IE7和IE6向下的浏览器对CSS的执行,达到兼容的目的。同时,首行默认的css.css还能与其他非IE浏览器实现兼容。正常就是默认的样式,对IE浏览器需要特殊处理的,才进行条件注释。
这里需要注意的是:默认的CSS样式应该位于HTML文档的首行,进行条件注释判断的所有内容必须位于该默认样式之后。
所以,这种方法可以直接根据浏览器来执行相应代码,比单独的CSS HACK要强大许多,这也是我们网站项目中常用的方法。
相关文章推荐
- html兼容IE中的<!--[if IE]--><!--[endif]-->说明
- <!–[if lte IE 6]>……<![endif]–>详解
- 通过HTML条件注释判断IE版本的HTML语句详解<!--[if IE]> <![endif]-->
- <!--[if IE]>….<![endif]--> (<!--[if !IE]>||<![endif]-->)的用法
- 【转】<!--[if IE]>….<![endif]--> (<!--[if !IE]>||<![endif]--> IE HTML识别
- 判断IE版本的HTML语句详解<!--[if IE]> <![endif]--> - AnswerCard
- < !--[if IE]> < ![endif]--> 条件注释
- <!--[if IE]><meta http-equiv="X-UA-Compatible" content="IE=Edge" /><![endif]-->不起作用。。
- 判断IE版本的HTML语句详解<!--[if IE]> <![endif]-->
- html中块注释<!--[if IE]>….<![endif]--> (<!--[if !IE]>||<![endif]
- <!--[if IE]>….<![endif]-->创建IE各版本专属CSS IE中的if语句
- <!--[if IE]>....<![endif]-->详解
- <!--[if IE]>….<![endif]--> (<!--[if !IE]>||<![endif]-->)
- <!--[if IE]><script type="text/javascript" src="matrix/js/html5.js"></script><![endif]-->代码解释
- <!--[if !IE]><![endif]-->解释
- HTML中IE条件注释判断语句(<!--[if XX IE X]><![endif]-->)
- <!--[if !IE]><![endif]-->解释
- HTML条件注释判断IE<!--[if IE]><!--[if lt IE 9]>
- HTML条件注释判断IE<!--[if IE]><!--[if lt IE 9]>
- [Asp.Net]<!--[if IE]>....<![endif]-->详解