`
FengShen_Xia
  • 浏览: 273206 次
  • 性别: Icon_minigender_1
  • 来自: 东方水城
社区版块
存档分类
最新评论

CSS条件注释

    博客分类:
  • CSS
阅读更多

由于浏览器版本的不同,对CSS里某些元素的解释也不一样,针对浏览器版本不同而选择不同CSS的代码,
其实我们还可以利用条件注释的方法来达到类似的目的,什么是条件注释,在此简单介绍一下,无非就是一些if判断啦,呵呵,但这些判断不是在脚本里执行的,而是直接在html代码里执行的,下面来介绍一下使用方法吧。

<!--[if XXX]>
这里是正常的html代码
<![endif]–>
这里XXX是一些特定的东东,在此列表几个出来,详细介绍各自的含义:
<!–[if IE]> / 如果浏览器是IE /
<!–[if IE 5]> / 如果浏览器是IE 5 的版本 /
<!–[if IE 6]> / 如果浏览器是IE 6 的版本 /
<!–[if IE 7]> / 如果浏览器是IE 7 的版本 /

上面是几个常用的判断IE浏览器版本的语法,下面再来介绍一下相对比较少用的逻辑判断的参数:
有几个参数:lte,lt,gte,gt及!
各自的详细解释如下:
lte:就是Less than or equal to的简写,也就是小于或等于的意思。
lt :就是Less than的简写,也就是小于的意思。
gte:就是Greater than or equal to的简写,也就是大于或等于的意思。
gt :就是Greater than的简写,也就是大于的意思。

例句:

<!--[if gt IE 5.5]> / 如果IE版本大于5.5 /
<!–[if lte IE 6]> / 如果IE版本小于等于6 /
<!–[if !IE]> / 如果浏览器不是IE /

看到这里相信大家都已经明白了条件注释的用法了,OK,那来举个例子吧:
<!-- 默认先调用css.css样式表 -->
<link rel="stylesheet" type="text/css" xhref="css.css" />
<!--[if !IE]>
<!– 非IE下调用1.css样式表 –>
<link rel=”stylesheet” type=”text/css” xhref=”1.css” />
<![endif]–>
<!–[if lt IE 6]>
<!– 如果IE浏览器版本小于6,调用2.css样式表 –>
<link rel=”stylesheet” type=”text/css” xhref=”2.css” />
<![endif]–>

定义什么浏览器下显示什么内容。
这个dropmenu(下拉菜单)模型来自cssplay,使经过作者多次的研究和反复的测试才做出来的。我想那这个模型来实践一下条件注释的原理。
先看一个最简单的模型
下面是xhtm:

<div class="menu">
<ul>
<li><a class="drop" xhref="../menu/index.html">DEMOS
<!--[if IE 7]><!–>
</a>
<!–<![endif]–>
<!–IE7时显示</a>标签–>
<table><tr><td>
<ul>
<li><a xhref=”../menu/zero_dollars.html” title=”The zero dollar ads page”>zero dollars advertising page</a></li>
<li><a xhref=”../menu/embed.html” title=”Wrapping text around images”>wrapping text around images</a></li>
<li><a xhref=”../menu/form.html” title=”Styling forms”>styled form</a></li>
<li><a xhref=”../menu/nodots.html” title=”Removing active/focus borders”>active focus</a></li>
<li><a class=”drop” xhref=”../menu/hover_click.html” title=”Hover/click with no active/focus borders”>hover/click with no borders</li>
<li class=”upone”><a xhref=”../menu/shadow_boxing.html” title=”Multi-position drop shadow”>shadow boxing</a></li>
<li><a xhref=”../menu/old_master.html” title=”Image Map for detailed information”>image map for detailed information</a></li>
<li><a xhref=”../menu/bodies.html” title=”fun with background images”>fun with background images</a></li>
<li><a xhref=”../menu/fade_scroll.html” title=”fade-out scrolling”>fade scrolling</a></li>
<li><a xhref=”../menu/em_images.html” title=”em size images compared”>em image sizes compared</a></li>
</ul>
</td></tr></table>
<!–[if lte IE 6]>
</a>
<![endif]–>
</li>
<!–IE6时显示</a>标签–>
</ul>
</div>
 

 

CSS

<link rel="stylesheet" media="all" type="text/css" xhref="final_drop.css" />
<!--[if lte IE 6]>
<link rel=”stylesheet” media=”all” type=”text/css” xhref=”final_drop_ie.css” />
<![endif]–>
 


采用双样式,给ie和非ie分别定义样式,如果IE时候,在final_drop.css基础上补充一个final_drop_ie.css
先看看非ie下的css是怎样定义的

.menu ul li ul {
display: none;
}
/* specific to non IE browsers */
.menu ul li:hover a {
color:#fff;
background:#bd8d5e;
}
/*定义鼠标滑过样式*/
.menu ul li:hover ul {
display:block;
position:absolute;
top:3em;
margin-top:1px;
left:0;
width:150px;
}
 

 

在非IE下,看到鼠标滑过时候li包含的ul显示了,因为这些浏览器支持li:hover用法
IE下的css

.menu ul li a:hover {
color:#fff;
background:#bd8d5e;
}
/*当鼠标滑过时li包含的ul显示*/
.menu ul li a:hover ul {
display:block;
position:absolute;
top:3em;
left:0;
background:#fff;
margin-top:0;
marg\in-top:1px;
}
 


继承上面的final_drop.css样式,无鼠标时间时候li包含的ul不显示
因为
<!--[if lte IE 6]>
</a>
<![endif]–>

评论

相关推荐

    css 条件注释使用指南

    条件注释的格式 所有可用的条件注释标签是基于相同的原理的。这些条件注释可用于所有的IE浏览器版本。 复制代码代码如下: &lt;!–[if IE]&gt; 如果用户使用IE浏览器,这里的信息会生效。 &lt;![end

    CSS条件注释详解(根据不同浏览器加载CSS)

    主要介绍了CSS条件注释详解(根据不同浏览器加载CSS)这也是现阶段最方便的各种浏览器兼容方式了,需要的朋友可以参考下

    css条件注释理论及实践源文件

    css条件注释理论及实践源文件

    CSS条件注释的使用详解教材

    CSS条件注释的使用详解教材

    div+css布局必须要知道的css条件注释理论及实践第1/2页

    div+css布局必须要知道的css条件注释理论及实践

    不同版本IE使用不同css(css条件注释语句用法)

    本文讲的是利用if来判断用户浏览器不同版本IE使用不同css,下面总结一些针对IE6、7、8条件注释语句用法

    css 条件注释区分非IE浏览器

    IE浏览器的条件注释虽不太常用,却异常强大,不仅可以用来区分IE浏览器版本

    针对主流浏览器的CSS-HACK写法及IE常用条件注释

    本文将为你总结CSS针对各浏览器的兼容HACK(以IE6/IE7/IE8 /FF为主),以及IE特有的条件注释使用方法.

    ie10 css hack 条件注释等兼容方式整理

    截至到现在,在ie6到ie9的浏览器各种各样的古怪行为,开发人员不得不使用条件注释,有条件的类,和其他特定于IE的css hack来解决。 ps:条件注释是一种安全的区分IE浏览器版本的语法,且被认为是取代针对IE css hack...

    条件CSS的高级用法

    条件CSS(Conditional-CSS)并不...核心思想建立在 Internet Explorer 上发现的条件注释方法,并扩展到包含其他的浏览器,而且将条件声明内联到 CSS 定义里面。 相关教程:针对不同版本的IE浏览器的条件CSS应用 条件CSS

    条件CSS基本使用方法

    条件 CSS 是这个问题的一个解决方案,采用的是 Internet Explorer 的条件注释语法的思想,并把它内联到 CSS 声明之中。 基本用法 条件 CSS 主要用于指出一个特别的 CSS 声明是不是应该用于一个特别的浏览器。当然你...

    条件 CSS的使用

    条件 CSS 是这个问题的一个解决方案,采用的是 Internet Explorer 的条件注释语法的思想,并把它内联到 CSS 声明之中。 基本用法 条件 CSS 主要用于指出一个特别的 CSS 声明是不是应该用于一个特别的浏览器。当然...

    面向XHTML的IE条件注释

    条件注释是IE特有的一种功能,能对IE系列产品进行单独的XHTML代码处理,注意,主要是针对XHTML,而非CSS。 条件注释功能非常强大,可以进行true和false判断,例如: 程序代码 &lt;!–[if IE]&gt;此内容只有IE可见&lt;!...

    IE 条件注释详解总结(附实例代码)

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

Global site tag (gtag.js) - Google Analytics