IE浏览器条件注释的详解
程序员文章站
2022-03-30 17:33:22
...
IE条件注释是微软从IE5开始就提供的一种非标准逻辑语句,作用是可以灵活的为不同IE版本浏览器导入不同html元素,如:样式表,html标签等。很显然这种方法的最大好处就在于属于微软官方给出的兼容解决办法而且还能通过W3C的效验。
让我们举几个例子来看看:
1、只有IE才能识别
<!--[if IE]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
因为只有IE5以上的版本才开始支持IE条件注释,所有“只有IE”才能识别的意思是“只有IE5版本以上”才能识别。
2、只有特定版本才能识别
<!--[if IE 8]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
识别特定的IE版本,高了或者低了都不可以。上例只有IE8才能识别。
3、只有不是特定版本的才能识别
<!--[if !IE 7]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
上例中特定IE7版本不能识别,其他版本都能识别,当然要在IE5以上。
4、只有高于特定版本才能识别
<!--[if gt IE 7]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
上例中只有高于IE7的版本才能识别。IE7无法识别。
5、等于或者高于特定版本才能识别
<!--[if gte IE 7]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
上例中IE7和更高的版本都能识别。
6、只有低于特定版本的才能识别
<!--[if lt IE 7]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
上例中只有低于IE7的版本才能识别,IE7无法识别。
7、等于或者低于特定版本的才能识别
<!--[if lte IE 7]> <link type="text/css" rel="stylesheet" href="my.css" /> <![endif]-->
上例中IE7和更低的版本可以识别。
关键词解释
上面那些代码好像很难记的样子,其实只要稍微解释一下关键字就很容易记住了。
lt:就是Less than的简写,也就是小于的意思。
lte:就是Less than or equal to的简写,也就是小于或等于的意思。
gt:就是Greater than的简写,也就是大于的意思。
gte:就是Greater than or equal to的简写,也就是大于或等于的意思。
!:就是不等于的意思,跟javascript里的不等于判断符相同。
这样解释一下,是不是好记多了。
特别提示:
1、有人会试图使用<!--[if !IE]>来定义非IE浏览器下的状况,但注意:条件注释只有在IE浏览器下才能执行,这个代码在非IE浏览下被当做注释视而不见。
2、我们通常用IE条件注释根据浏览器不同载入不同css,从而解决样式兼容性问题的。其实它可以做的更多。它可以保护任何代码块——HTML代码块、JavaScript代码块、服务器端代码……看看下面的代码。
<!--[if IE]> <script type="text/javascript"> alert("你使用的是IE浏览器!"); </script> <![endif]-->
以上就是IE浏览器条件注释的详解的详细内容,更多请关注其它相关文章!
推荐阅读
-
ie浏览器 弹出的div被内嵌iframe遮盖_html/css_WEB-ITnose
-
当把宽度设为25%时,其他浏览器正常,IE7图片会掉下来,有没有好的解决方法_html/css_WEB-ITnose
-
数据库中排序的对比及使用条件详解_PHP
-
JavaScript在IE和Firefox浏览器下的7个差异兼容写法小结_javascript技巧
-
如何用CSS修改浏览器滚动条的样式(实例详解)
-
在JPA的@Query注解中使用limit条件(详解)
-
CSS条件注释的使用详解教材
-
都是IE惹的祸多浏览器兼容问题
-
HTML下在IE浏览器中的专有条件注释讲解
-
div+css布局必须要知道的css条件注释理论及实践第1/2页