您现在的位置是:网站首页> 编程资料编程资料

编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu_经验交流_

2023-05-25 304人已围观

简介 编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu_经验交流_

编写纯 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. http://www.w3.org/TR/html4/loose.dtd">
  2. Untitled Document
  3. /*
  4.     body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
  5.     *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
  6.     .pmVerticalRightOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
  7.     .pmVerticalRightOut .level{  /* 定义一级类别属性 */
  8.         width:120px; /* 宽度 */
  9.         height:17; /* 高度 */
  10.         position:relative; /* 显示位置为相对位置 */
  11.         display:block; /* 以块模式显示 */
  12.         background-color:#D8D8D8; /* 背景色 */
  13.         padding:0px 2px; /* 文字内补丁间隔 */
  14.         margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
  15.     }
  16.     .pmVerticalRightOut .level:hover { /* 当鼠标划过一级菜单时 */
  17.         background-color:#6633FF; /* 背景色 */
  18.         color:#FFFFFF; /* 文字颜色 */
  19.     }
  20.     .pmVerticalRightOut .level_{display:none; /* 默认隐藏二级类别 */}
  21.     
  22.     .pmVerticalRightOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
  23.         display:block; /* 以块显示 */
  24.         left:124px; /* 相对于一级类别显示的位置 */
  25.         width:120px; /* 宽度 */
  26.         height:auto; /* 高度 */
  27.         top:0px; /* 相对于一级类别所在位置的顶端 */
  28.         background-color:#EFEFEF; /* 定义背景色 */
  29.         position:absolute; /* 位置为绝对位置 */
  30.     }
  31.     .pmVerticalRightOut .level:hover .level_ .level_title {
  32.         /* 定义二级类别标题样式 */
  33.         font-weight:bold; /* 字体加粗 */
  34.         background-color:#A7ADFE; /* 背景色 */
  35.         color:white; /* 文字颜色 */
  36.     }
  37.     .pmVerticalRightOut .level:hover .level_ a:hover {
  38.         /* 定义二级类别链接显示样式 */
  39.         background-color:#F83658; /* 背景色 */
  40.         color:white; /* 文字颜色 */
  41.     }
  42.     .pmVerticalRightOut .level_ * { 
  43.         /* 定义所有二级类别通用属性 */
  44.         display:block; /* 以块显示 */
  45.         color:black; /* 文字颜色 */
  46.         padding:0px 2px; /* 内补丁间隔 */
  47.     }
  48. /*]]>*/
  49.     
  50.         level
  •         
  •             level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             level_ title 4
  •             level_ title 5
  •         
  •     
  •     
  •         level 1
  •         
  •             level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             level_ title 4
  •             level_ title 5
  •         
  •     
  •     
  •         level 2
  •         
  •             level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             level_ title 4
  •             level_ title 5
  •         
  •     
  •     
  •         level 3
  •         
  •             level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             level_ title 4
  •             level_ title 5
  •         
  •     
  •     
  •         level 4
  •         
  •             level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             level_ title 4
  •             level_ title 5
  •         
  •     

  • 1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
      linenum
    1. http://www.w3.org/TR/html4/loose.dtd">
    2. Untitled Document
    3. /*
    4.     body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    5.     *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    6.     /* ------------------- start 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    7.     .pmVerticalRightOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    8.     .pmVerticalRightOut .level{  /* 定义一级类别属性 */
    9.         width:120px; /* 宽度 */
    10.         height:17; /* 高度 */
    11.         position:relative; /* 显示位置为相对位置 */
    12.         display:block; /* 以块模式显示 */
    13.         background-color:#D8D8D8; /* 背景色 */
    14.         padding:0px 2px; /* 文字内补丁间隔 */
    15.         margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    16.     }
    17.     .pmVerticalRightOut .level:hover { /* 当鼠标划过一级菜单时 */
    18.         background-color:#6633FF; /* 背景色 */
    19.         color:#FFFFFF; /* 文字颜色 */
    20.     }
    21.     .pmVerticalRightOut .level_{display:none; /* 默认隐藏二级类别 */}
    22.     
    23.     .pmVerticalRightOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
    24.         display:block; /* 以块显示 */
    25.         left:124px; /* 相对于一级类别显示的位置 */
    26.         width:120px; /* 宽度 */
    27.         height:auto; /* 高度 */
    28.         top:0px; /* 相对于一级类别所在位置的顶端 */
    29.         background-color:#EFEFEF; /* 定义背景色 */
    30.         position:absolute; /* 位置为绝对位置 */
    31.     }
    32.     .pmVerticalRightOut .level:hover .level_ .level_title {
    33.         /* 定义二级类别标题样式 */
    34.         font-weight:bold; /* 字体加粗 */
    35.         background-color:#A7ADFE; /* 背景色 */
    36.         color:white; /* 文字颜色 */
    37.     }
    38.     .pmVerticalRightOut .level:hover .level_ a:hover {
    39.         /* 定义二级类别链接显示样式 */
    40.         background-color:#F83658; /* 背景色 */
    41.         color:white; /* 文字颜色 */
    42.     }
    43.     .pmVerticalRightOut .level:hover .level_ * { 
    44.         /* 定义所有二级类别通用属性 */
    45.         display:block; /* 以块显示 */
    46.         color:black; /* 文字颜色 */
    47.         padding:0px 2px; /* 内补丁间隔 */
    48.     }
    49.     /* ------------------- end 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    50.     
    51.     /* ------------------- start 针对 IE 的 CSS 弹出菜单 -------------------*/
    52.     .levelIe{  /* 定义一级类别属性 */
    53.         width:120px; /* 宽度 */
    54.         height:17; /* 高度 */
    55.         position:relative; /* 显示位置为相对位置 */
    56.         display:block; /* 以块模式显示 */
    57.         background-color:#D8D8D8; /* 背景色 */
    58.         padding:0px 2px; /* 文字内补丁间隔 */
    59.         margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    60.     }
    61.     .levelIe .level_ { /* 鼠标划过时触发显示二级类别 */
    62.         display:block; /* 以块显示 */
    63.         left:124px; /* 相对于一级类别显示的位置 */
    64.         width:120px; /* 宽度 */
    65.         height:auto; /* 高度 */
    66.         top:0px; /* 相对于一级类别所在位置的顶端 */
    67.         background-color:#EFEFEF; /* 定义背景色 */
    68.         position:absolute; /* 位置为绝对位置 */
    69.     }
    70. 提示: 本文由整理自网络,如有侵权请联系本站删除!
      本站声明:
      1、本站所有资源均来源于互联网,不保证100%完整、不提供任何技术支持;
      2、本站所发布的文章以及附件仅限用于学习和研究目的;不得将用于商业或者非法用途;否则由此产生的法律后果,本站概不负责!

    -六神源码网