当前位置: 代码迷 >> Web前端 >> IE的有条件诠释解析
  详细解决方案

IE的有条件诠释解析

热度:213   发布时间:2012-11-06 14:07:00.0
IE的有条件注释解析

IE的有条件注释是一种专有的非标准的,对常规(XHTML注释的Microsoft扩展。有条件注释在Windows上的IE5中首次出现,并且得到了Widnows浏览器所有后续版本的支持。

???????? IE的有条件注释及其有效,而且非常容易记住。主要的缺点是这些注释需要放在HTML页面中,而不是放在CSS中。这样,当你不需要这些东西,或者有所更改的时候,就需要维护很多的地方。

只有IE才能识别

??? 因为只有IE5以上的版本才开始支持IE条件注释,所有只有IE”才能识别的意思是只有IE5版本以上才能识别。

???????? <!--[if ?IE]>

???????????????? <style type=”text/css”>

????????????????????? ?@import “test.css”;

???????????? </style>

??????? <![endif]-->

只有特定版本才能识别

??? 例如,只有IE5才能识别,只有IE6才能识别,只有IE7或者IE8才能识别。识别的条件是特定的版本,高了或者低了都不可以。例如下面的代码块,将只会在IE8中有效

??????? ?<!―[if IE 8]>

??????????? ?<style type=”text/css”>

??????????????? ? @import “test.css”;

???????????? </style>

?????????<![endif]-->

只有不是特定版本的才能识别

??? 当然,IE浏览器需要在5以上的版本,才在讨论范围之内。例如下面的例子中,特定了

IE7版本不能识别。

????? <!―[if !IE 7]>

???????? ?<style type=”text/css”>

??????????? ? @import “text.css”;

?????? ?</style>

???? ?<![endif]-->

只有高于特定版本才能识别

??? 只有高于制定版本的IE浏览器才能识别的代码块。

????? <!--[if gt IE 7]>
??????? ?<style type="text/css">
?????????? ? @import "test.css";
??????? ?</style>
???? <![endif]-->

?????? 有朋友会问,为什么IE7没有应用到效果呢?那是因为IE7等于IE7,而不是高于IE7

所有IE7也没有起效果。

等于或者高于特定版本才能识别

????? <!--[if gte IE 7]>
??????? <style type="text/css">
????????? ? @import "test.css";
??????? </style>
????? <![endif]-->

只有低于特定版本的才能识别

???? <!--[if lt IE 7]>
??????? <style type="text/css">
?????????? @import "test.css";
??????? </style>
??? <![endif]-->

?等于或者低于特定版本的才能识别

???? <!--[if lte IE 7]>
??????? <style type="text/css">
?????????? ?@import "test.css";
??????? </style>
??? <![endif]-->

? 关键词解释

????? 上面那些代码好像很难记的样子,其实只要稍微解释一下关键字就很容易记住了。

??????? lt :就是Less than的简写,也就是小于的意思。

??????? lte :就是Less than or equal to的简写,也就是小于或等于的意思。

??????? gt :就是Greater than的简写,也就是大于的意思。

??????? gte:就是Greater than or equal to的简写,即大于或等于的意思。

??????? !:就是不等于的意思,跟javascript里的不等于判断符相同

??? 这样解释一下,是不是好记多了。

关于IE条件注释的特别说明

只有IE才能识别哦――
?? 曾经看到过下面的代码,现在想起来不禁有点想笑。这样的代码有什么意义吗?

????? <!--[if !IE]>
????????? <style type="text/css">
??????????? ? @import "test.css";
????????? </style>
???? <![endif]-->

不仅仅是CSS

????????? 很长时间,我对这个都有一种误解――以为它就是用来根据浏览器不同载入不同css,从而解决样式兼容性问题的。其实,我错了。它其实可以做的更多。它可以保护任何代码块――HTML代码块、JavaScript代码块、服务器端代码……看看下面的代码。

???????? <!--[if IE]>

?????????? 你使用的是IE浏览器,还会弹出个框哦。

???????????? <script type="text/javascript">

??????????? alert("你使用的是IE浏览器!");

??????? </script>

?? <![endif]-->

?

?

?

?

?

  相关解决方案