当前位置: 首页 > 图文教程 > 网页制作 > HTML/XHTML教程 > IE的有条件注释优点和缺点

HTML/XHTML教程
HTML5之后W3C将制定无版本号的HTML
IE6必然灭亡的最新6个理由
网页制作教程:单独对IE6进行兼容
Firefox 3.6频繁崩溃的问题
HTML5的发展:微格式和相关的属性名称
Chrome最新4.0版本支持GreaseMonkey脚本
网页前端常见的攻击方式和预防攻击办法
HTML5标准将把互联网视频扔回到黑暗时代
靠我们自己的力量把IE6推向灭亡
近期热点:HTML5是否真的可以取代Flash
网页知识新手了解:网页设计的发展历史
TinyEditor:简洁且易用的html所见即所得编辑器
ANSI,Unicode,UTF-8网页编码的区别
HTML5实例:20个使用HTML5编写的网站
网页表单设计:主要行为与次要行为
HTML网页实例代码:简洁漂亮的跳转等待页面
经验分享:关于网页布局排版的流程问题
W3C发布7个HTML工作草案
HTML5 旨在解决 Web 中的交互
网页优化的最基础部分:HTML的优化

HTML/XHTML教程 中的 IE的有条件注释优点和缺点


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-13   浏览: 91 ::
收藏到网摘: n/a

IE的有条件注释是一种专有的(因此是非标准的)、对常规(X)HTML注释的Miscrosoft扩展。顾名思义,有条件注释使你能够根据条件(比如浏览器版本)显示代码块。尽管是非标准的,但是有条件注释对于其他所有浏览器作为常规注释出现,因此本质上是无害的。有条件注释在Windows上的IE5中首次出现,并且得到了Widnows浏览器所有后续版本的支持。

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

让我们据几个例子来看看吧——

只有IE才能识别

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

只有特定版本才能识别

例如,只有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 "test.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]-->

 

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