当前位置: 首页 > news >正文

IE的有条件注释详解(附实例代码)

转自:http://www.cnblogs.com/JustinYoung/archive/2009/03/02/ie-jiaojianzhushi.html

 

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

IE的有条件注释是一种专有的(因此是非标准的)、对常规(X)HTML注释的Miscrosoft扩展。顾名思义,有条件注释使你能够根据条件(比如浏览器版本)显示代码块。尽管是非标准的,但是有条件注释对于其他所有浏览器作为常规注释出现,因此本质上是无害的。有条件注释在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共存

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

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

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

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

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

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

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

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

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

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

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

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

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

关键词解释

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

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]-->

相关文章:

  • [数据恢复答疑]误GHOST之后的数据还能恢复吗?
  • 如何解决IE部分图片不显示
  • 配置ASA IPSec ××× With OSPF
  • 图片上传时应该注意的内容
  • 学习Unix下C编程的实例
  • css学习ing
  • 域控制器之操作主机中应注意的一些常见问题
  • 一个让人遗忘的角落—Exception(二)
  • 常用JS函数之二(页面验证等)
  • CISCO认证体系专题
  • IT民工:我的明天在哪里?
  • mysql日志生成
  • 245566
  • 解决使用nvelocity时候template文件里面包含中文输出结果时候出现乱码的问题
  • IT基础结构-4.BDNS-安装与配置
  • 《Javascript数据结构和算法》笔记-「字典和散列表」
  • 《深入 React 技术栈》
  • 【面试系列】之二:关于js原型
  • FineReport中如何实现自动滚屏效果
  • flutter的key在widget list的作用以及必要性
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • iOS小技巧之UIImagePickerController实现头像选择
  • Iterator 和 for...of 循环
  • JavaScript设计模式之工厂模式
  • Java读取Properties文件的六种方法
  • Laravel Mix运行时关于es2015报错解决方案
  • Map集合、散列表、红黑树介绍
  • PAT A1120
  • SQL 难点解决:记录的引用
  • use Google search engine
  • v-if和v-for连用出现的问题
  • vue-cli3搭建项目
  • vue总结
  • 初探 Vue 生命周期和钩子函数
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 开发基于以太坊智能合约的DApp
  • 理解在java “”i=i++;”所发生的事情
  • 我是如何设计 Upload 上传组件的
  • 一道面试题引发的“血案”
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • # 数据结构
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • (4)logging(日志模块)
  • (独孤九剑)--文件系统
  • (附源码)ssm教师工作量核算统计系统 毕业设计 162307
  • (附源码)计算机毕业设计高校学生选课系统
  • (转)linux下的时间函数使用
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • *Algs4-1.5.25随机网格的倍率测试-(未读懂题)
  • .axf 转化 .bin文件 的方法
  • .class文件转换.java_从一个class文件深入理解Java字节码结构
  • .Net 8.0 新的变化
  • .NET Core MongoDB数据仓储和工作单元模式封装
  • .NET Core 通过 Ef Core 操作 Mysql