首页 > web前端 > css教程 > 正文

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

php中文网
发布: 2016-05-16 12:08:46
原创
5530人浏览过

编写纯 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. nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  2. http://www.w3.org/TR/html4/loose.dtd">
  3. Untitled Document
  4.     
  5.         
    level
  6.         
  7.             
    level_ title
  8.             level_ title 1
  9.             level_ title 2
  10.             level_ title 3
  11.             level_ title 4
  12.             level_ title 5
  13.         
  •     
  •     
  •         
    level 1
  •         
  •             
    level_ title
  •             level_ title 1
  •             level_ title 2
  •             level_ title 3
  •             http://www.w3.org/TR/html4/loose.dtd0
  •             http://www.w3.org/TR/html4/loose.dtd1
  •         
  •     
  •     
  •         
    level 2
  •         
  •             
    level_ title
  •             http://www.w3.org/TR/html4/loose.dtd2
  •             http://www.w3.org/TR/html4/loose.dtd3
  •             http://www.w3.org/TR/html4/loose.dtd4
  •             http://www.w3.org/TR/html4/loose.dtd5
  •             http://www.w3.org/TR/html4/loose.dtd6
  •         
  •     
  •     
  •         
    level 3
  •         
  •             
    level_ title
  •             http://www.w3.org/TR/html4/loose.dtd7
  •             http://www.w3.org/TR/html4/loose.dtd8
  •             http://www.w3.org/TR/html4/loose.dtd9
  •             level_ title 10
  •             level_ title 11
  •         
  •     
  •     
  •         
    level 4
  •         
  •             
    level_ title
  •             level_ title 12
  •             level_ title 13
  •             level_ title 14
  •             level_ title 15
  •             level_ title 16
  •         
  •     

  • 1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
      linenum
    1. nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
    2. http://www.w3.org/TR/html4/loose.dtd">
    3. Untitled Document
    4. <script> <LI>//<![CDATA[ <LI>if (navigator.appName=="Microsoft Internet Explorer") { <LI> function fPmVerticalRightOut() { <LI> var getItem = document.getElementById("pmVerticalRightOut").getElementsByTagName("div"); <LI> for (var i=0; i<getItem.length; i++) { <LI> getItem[i].onmouseover=function() { <LI> if( this.className=="level"){ <LI> this.className="levelIe"; <LI> } <LI> } <LI> getItem[i].onmouseout=function() { <LI> if( this.className=="levelIe"){ <LI> this.className="level"; <LI> } <LI> }//css popup menu script by shawl.qiu <LI> } <LI> } <LI> window.onload=fPmVerticalRightOut; <LI>} <LI>//]]> <LI></script>
    5.     
    6.         
      level
    7.         
    8.             
      level_ title
    9.             level_ title 1
    10.             level_ title 2
    11.             level_ title 3
    12.             level_ title 4
    13.             level_ title 5
    14.         
    15.     
    16.     
    17.         
      level 1
    18.         
    19.             
      level_ title
    20.             level_ title 1
    21.             level_ title 2
    22.             level_ title 3
    23.             http://www.w3.org/TR/html4/loose.dtd0
    24.             http://www.w3.org/TR/html4/loose.dtd1
    25.         
    26.     
    27.     
    28.         
      level 2
    29.         
    30.             
      level_ title
    31.             http://www.w3.org/TR/html4/loose.dtd2
    32.             http://www.w3.org/TR/html4/loose.dtd3
    33.             http://www.w3.org/TR/html4/loose.dtd4
    34.             http://www.w3.org/TR/html4/loose.dtd5
    35.             http://www.w3.org/TR/html4/loose.dtd6
    36.         
    37.     
    38.     
    39.         
      level 3
    40.         
    41.             
      level_ title
    42.             http://www.w3.org/TR/html4/loose.dtd7
    43.             http://www.w3.org/TR/html4/loose.dtd8
    44.             http://www.w3.org/TR/html4/loose.dtd9
    45.             level_ title 10
    46.             level_ title 11
    47.         
    48.     
    49.     
    50.         
      level 4
    51.         
    52.             
      level_ title
    53.             level_ title 12
    54.             level_ title 13
    55.             level_ title 14
    56.             level_ title 15
    57.             level_ title 16
    58.         
    59.     

    2. 编写横排底部弹出的 CSS 菜单. 

    2.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
      linenum
    1. nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
    2. http://www.w3.org/TR/html4/loose.dtd">
    3. Untitled Document
    4.     
    5.         
      level
    6.         
    7.             
      level_ title
    8.             level_ title 1
    9.             level_ title 2
    10.             level_ title 3
    11.             level_ title 4
    12.             level_ title 5
    13.         
    14.     
    15.     
    16.         
      level 1
    17.         
    18.             
      level_ title
    19.             level_ title 1
    20.             level_ title 2
    21.             level_ title 3
    22.             http://www.w3.org/TR/html4/loose.dtd0
    23.             http://www.w3.org/TR/html4/loose.dtd1
    24.         
    25.     
    26.     
    27.         
      level 2
    28.         
    29.             
      level_ title
    30.             http://www.w3.org/TR/html4/loose.dtd2
    31.             http://www.w3.org/TR/html4/loose.dtd3
    32.             http://www.w3.org/TR/html4/loose.dtd4
    33.             http://www.w3.org/TR/html4/loose.dtd5
    34.             http://www.w3.org/TR/html4/loose.dtd6
    35.         
    36.     
    37.     
    38.         
      level 3
    39.         
    40.             
      level_ title
    41.             http://www.w3.org/TR/html4/loose.dtd7
    42.             http://www.w3.org/TR/html4/loose.dtd8
    43.             http://www.w3.org/TR/html4/loose.dtd9
    44.             level_ title 10
    45.             level_ title 11
    46.         
    47.     
    48.     
    49.         
      level 4
    50.         
    51.             
      level_ title
    52.             level_ title 12
    53.             level_ title 13
    54.             level_ title 14
    55.             level_ title 15
    56.             level_ title 16
    57.         
    58.     

    2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
      linenum
    1. nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
    2. " http://www.w3.org/TR/html4/loose.dtd">
    3. Untitled Document
    4. <script> <LI>//<![CDATA[ <LI>if (navigator.appName=="Microsoft Internet Explorer") { <LI> function fPmHorizontalBottomOut() { <LI> var getItem = document.getElementById("pmHorizontalBottomOut").getElementsByTagName("div"); <LI> for (var i=0; i<getItem.length; i++) { <LI> getItem[i].onmouseover=function() { <LI> if( this.className=="level"){ <LI> this.className="levelIe"; <LI> } <LI> } <LI> getItem[i].onmouseout=function() { <LI> if( this.className=="levelIe"){ <LI> this.className="level"; <LI> } <LI> }//css popup menu script by shawl.qiu <LI> } <LI> } <LI> window.onload=fPmHorizontalBottomOut; <LI>} <LI>//]]> <LI></script>
    5.     
    6.         
      level
    7.         
    8.             
      level_ title
    9.             level_ title 1
    10.             level_ title 2
    11.             level_ title 3
    12.             level_ title 4
    13.             level_ title 5
    14.         
    15.     
    16.     
    17.         
      level 1
    18.         
    19.             
      level_ title
    20.             level_ title 1
    21.             level_ title 2
    22.             level_ title 3
    23.             http://www.w3.org/TR/html4/loose.dtd0
    24.             http://www.w3.org/TR/html4/loose.dtd1
    25.         
    26.     
    27.     
    28.         
      level 2
    29.         
    30.             
      level_ title
    31.             http://www.w3.org/TR/html4/loose.dtd2
    32.             http://www.w3.org/TR/html4/loose.dtd3
    33.             http://www.w3.org/TR/html4/loose.dtd4
    34.             http://www.w3.org/TR/html4/loose.dtd5
    35.             http://www.w3.org/TR/html4/loose.dtd6
    36.         
    37.     
    38.     
    39.         
      level 3
    40.         
    41.             
      level_ title
    42.             http://www.w3.org/TR/html4/loose.dtd7
    43.             http://www.w3.org/TR/html4/loose.dtd8
    44.             http://www.w3.org/TR/html4/loose.dtd9
    45.             level_ title 10
    46.             level_ title 11
    47.         
    48.     
    49.     
    50.         
      level 4
    51.         
    52.             
      level_ title
    53.             level_ title 12
    54.             level_ title 13
    55.             level_ title 14
    56.             level_ title 15
    57.             level_ title 16
    58.         
    59.     


    3. 结论
    以上例子可以看出, 如果已经编写出一个可用的CSS弹出菜单例子, 那要编写出弹出位置在其他地方的 CSS 弹出菜单的话, 只须小小修改一下就 OK. 

    4. 预览

    4.1 1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现) 的预览
    最佳 Windows 性能的顶级免费优化软件
    最佳 Windows 性能的顶级免费优化软件

    每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

    下载
    相关标签:
    css
    来源:php中文网
    收藏 点赞
    上一篇:Lesson02_05 头元素_基础教程 下一篇:Lesson02_04 表单标签(2)_基础教程
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    相关专题
    更多>
    热门推荐
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习
    PHP中文网抖音号
    发现有趣的

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号