当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > css写菜单:简洁注释版

CSS样式表
CSS实例代码:网页背景渐变
CSS教程:dashed和dotted的区别
各种不同的浏览器对CSS3和HTML5的支持状况
15个高质量免费的WEB标准网站模板
Firefox Bug: inline/inline-block的间隙
CSS网页布局问题:li上多出的margin问题
css reset样式初始化
CSS解决链接锚点定位偏移
CSS设置的背景图片在IE7中点击消失
CSS教程:兼容ie6,ie7,ff的fixed
css网页布局中文字排版的属性和用法
CSS Sprites探讨
CSS Tricks精选出的一些精灵图片
40个有吸引力的导航菜单实例
CSS3实例教程:倾斜的网页图片库
遵循web标准 网页前端得3类优化
CSS 3给我们带来了什么惊喜?
网页重构:由网页图标处理引发的思考
CSS代码:控制IE滚动条
CSS实例教程:用ul li做圆角表格

CSS样式表 中的 css写菜单:简洁注释版


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

这里是简洁版,主要把 [ 显示/隐藏 ] 效果给剥离出来给大家研究。
主要是利用了a:hover[ie],li:hover[非ie]的状态来做出显示/隐藏菜单的效果。
关键之处:
程序代码
<!--[if IE 7]><!--></a><!--<![endif]-->
这一段注释表示:只有非IE浏览器和IE7才能读取到 </a>
这样在非IE浏览器及IE7版本的浏览器中读取到的html是:
程序代码
<li><a href="#">导航</a>
<ul><li>二级导航</li></ul>
</li>
程序代码
<!--[if lte IE 6]></a><![endif]-->
这一段注释代表:只有IE6以及IE6以下版本的浏览器才能读取到 </a>
而在IE6以及IE6以下版本的浏览器中读取到的html就是:
程序代码
<li><a href="#">导航
<ul><li>二级导航</li></ul>
</a>
</li>
有些朋友可能要问:为什么要搞的那么复杂,而不都用链接来包含二级列表呢,那样就只用写a:hover就可以了,代码简单多了。
我个人觉得:
玩标准就要尽可能的去遵循语义。
在IE6以及以下版本中由于不支持a以外标记的hover伪类,所以目前来说只有这个办法能达到类似的目的,对着IE6...只好放弃语义了。
但我们可不要为了一个IE6而坏了整锅汤哦,所以有些事情虽然麻烦了点,但还是要做的~
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

注意里面是分段的,[ 随意发挥 ] 。俺先来发挥一下~ (原先没注意兼容,现在兼容了...)
点击运行可以看到效果:
[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]