日期:2013-10-02  浏览次数:21210 次

编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu


摘要: 
本文引见了使用 CSS 编写适用于 Opera, Firefox, IE 的多风格弹出菜单

说明:
编写 CSS 弹出菜单的要点不外乎当鼠标移到目标上时, 显示出隐藏的标签. 
要隐藏的标签使用 display:none; 属性进行隐藏. 
触发显示隐藏标签次要使用 :hover 属性, 并用 display:block; 显示隐藏的标签.

但由于浏览器对 CSS 的支持并非分歧.
对于 Opera 或者 Firefox, 我们可以编写出纯 CSS 菜单, 他们支持任何标签的 :hover 属性.
而对于 IE 浏览器, :hover 只对 a 标签起作用, 但我们可以使用脚本的 onmouseover, onmouseout 模仿出其他标签的 :hover 属性.
因此编写适用于 IE 的 CSS 弹出菜单必须使用到少许的脚本.

目录:
1. 编写直排右侧弹出的 CSS 菜单. 
1.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)

2. 编写横排底部弹出的 CSS 菜单. 
2.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)

3. 结论

4. 预览

shawl.qiu
2006-10-01
http://blog.csdn.net/btbtd

1. 编写直排右侧弹出的 CSS 菜单. 

1.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
    linenum
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  2. http://www.w3.org/TR/html4/loose.dtd">
  3. <html>
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  6. <title>Untitled Document</title>
  7. <style type="text/css">
  8. /*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
  9.     body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
  10.     *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
  11.     .pmVerticalRightOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
  12.     .pmVerticalRightOut .level{  /* 定义一级类别属性 */
  13.         width:120px; /* 宽度 */
  14.         height:17; /* 高度 */
  15.         position:relative; /* 显示位置为绝对位置 */
  16.         display:block; /* 以块模式显示 */
  17.         background-color:#D8D8D8; /* 背景色 */
  18.         padding:0px 2px; /* 文字内补丁间隔 */
  19.         margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
  20.     }
  21.     .pmVerticalRightOut .level:hover { /* 当鼠标划过一级菜单时 */
  22.         background-color:#6633FF; /* 背景色 */
  23.         color:#FFFFFF; /* 文字颜色 */
  24.     }
  25.     .pmVerticalRightOut .level_{display:none; /* 默认隐藏二级类别 */}
  26.     
  27.     .pmVerticalRightOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
  28.         display:block; /* 以块显示 */
  29.         left:124px; /* 绝对于一级类别显示的位置 */
  30.   &