编写纯 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
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
" http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Untitled Document</title>
<style type="text/css">
/*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
    body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    .pmVerticalRightOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    .pmVerticalRightOut .level{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    }
    .pmVerticalRightOut .level:hover { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .pmVerticalRightOut .level_{display:none; /* 默认隐藏二级类别 */}
    
    .pmVerticalRightOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        left:124px; /* 相对于一级类别显示的位置 */
        width:120px; /* 宽度 */
        height:auto; /* 高度 */
        top:0px; /* 相对于一级类别所在位置的顶端 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .pmVerticalRightOut .level:hover .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmVerticalRightOut .level:hover .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmVerticalRightOut .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
/*]]>*/
</style>
</head>
<body>
<p/><p/><p/><p/><p/>
<div class="pmVerticalRightOut" id="pmVerticalRightOut">
    <div class="level">
        <div class="levelTitle">level</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level&id=1">level_ title 1</a>
            <a href="?cat=level&id=2">level_ title 2</a>
            <a href="?cat=level&id=3">level_ title 3</a>
            <a href="?cat=level&id=4">level_ title 4</a>
            <a href="?cat=level&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 1</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_1&id=1">level_ title 1</a>
            <a href="?cat=level_1&id=2">level_ title 2</a>
            <a href="?cat=level_1&id=3">level_ title 3</a>
            <a href="?cat=level_1&id=4">level_ title 4</a>
            <a href="?cat=level_1&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 2</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_2&id=1">level_ title 1</a>
            <a href="?cat=level_2&id=2">level_ title 2</a>
            <a href="?cat=level_2&id=3">level_ title 3</a>
            <a href="?cat=level_2&id=4">level_ title 4</a>
            <a href="?cat=level_2&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 3</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_3&id=1">level_ title 1</a>
            <a href="?cat=level_3&id=2">level_ title 2</a>
            <a href="?cat=level_3&id=3">level_ title 3</a>
            <a href="?cat=level_3&id=4">level_ title 4</a>
            <a href="?cat=level_3&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 4</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_4&id=1">level_ title 1</a>
            <a href="?cat=level_4&id=2">level_ title 2</a>
            <a href="?cat=level_4&id=3">level_ title 3</a>
            <a href="?cat=level_4&id=4">level_ title 4</a>
            <a href="?cat=level_4&id=5">level_ title 5</a>
        </div>
    </div>
</div>
</body>
</html>
1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
linenum
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
" http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Untitled Document</title>
<style type="text/css">
/*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
    body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    /* ------------------- start 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    .pmVerticalRightOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    .pmVerticalRightOut .level{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    }
    .pmVerticalRightOut .level:hover { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .pmVerticalRightOut .level_{display:none; /* 默认隐藏二级类别 */}
    
    .pmVerticalRightOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        left:124px; /* 相对于一级类别显示的位置 */
        width:120px; /* 宽度 */
        height:auto; /* 高度 */
        top:0px; /* 相对于一级类别所在位置的顶端 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .pmVerticalRightOut .level:hover .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmVerticalRightOut .level:hover .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmVerticalRightOut .level:hover .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
    /* ------------------- end 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    
    /* ------------------- start 针对 IE 的 CSS 弹出菜单 -------------------*/
    .levelIe{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    }
    .levelIe .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        left:124px; /* 相对于一级类别显示的位置 */
        width:120px; /* 宽度 */
        height:auto; /* 高度 */
        top:0px; /* 相对于一级类别所在位置的顶端 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .levelIe .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
    /* ------------------- end 针对 IE 的 CSS 弹出菜单 -------------------*/
/*]]>*/
</style>
<script type="text/javascript">
//<![CDATA[
if (navigator.appName=="Microsoft Internet Explorer") {
    function fPmVerticalRightOut() {
        var getItem = document.getElementById("pmVerticalRightOut").getElementsByTagName("div");
        for (var i=0; i<getItem.length; i++) {
            getItem[i].onmouseover=function() { 
                if(    this.className=="level"){
                    this.className="levelIe";
                }
            }
            getItem[i].onmouseout=function() { 
                if(    this.className=="levelIe"){
                    this.className="level";
                }
            }//css popup menu script by shawl.qiu
        }
    }
    window.onload=fPmVerticalRightOut;
}
//]]>
</script>
</head>
<body>
<p/><p/><p/><p/><p/>
<div class="pmVerticalRightOut" id="pmVerticalRightOut">
    <div class="level">
        <div class="levelTitle">level</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level&id=1">level_ title 1</a>
            <a href="?cat=level&id=2">level_ title 2</a>
            <a href="?cat=level&id=3">level_ title 3</a>
            <a href="?cat=level&id=4">level_ title 4</a>
            <a href="?cat=level&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 1</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_1&id=1">level_ title 1</a>
            <a href="?cat=level_1&id=2">level_ title 2</a>
            <a href="?cat=level_1&id=3">level_ title 3</a>
            <a href="?cat=level_1&id=4">level_ title 4</a>
            <a href="?cat=level_1&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 2</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_2&id=1">level_ title 1</a>
            <a href="?cat=level_2&id=2">level_ title 2</a>
            <a href="?cat=level_2&id=3">level_ title 3</a>
            <a href="?cat=level_2&id=4">level_ title 4</a>
            <a href="?cat=level_2&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 3</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_3&id=1">level_ title 1</a>
            <a href="?cat=level_3&id=2">level_ title 2</a>
            <a href="?cat=level_3&id=3">level_ title 3</a>
            <a href="?cat=level_3&id=4">level_ title 4</a>
            <a href="?cat=level_3&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 4</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_4&id=1">level_ title 1</a>
            <a href="?cat=level_4&id=2">level_ title 2</a>
            <a href="?cat=level_4&id=3">level_ title 3</a>
            <a href="?cat=level_4&id=4">level_ title 4</a>
            <a href="?cat=level_4&id=5">level_ title 5</a>
        </div>
    </div>
</div>
</body>
</html>
2. 编写横排底部弹出的 CSS 菜单. 

2.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
linenum
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
" http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Untitled Document</title>
<style type="text/css">
/*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
    body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    .pmHorizontalBottomOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    .pmHorizontalBottomOut .level{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 1px 0px 0px; /* 菜单外补丁间隔 */
        float:left;
    }
    .pmHorizontalBottomOut .level:hover { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level_{display:none; /* 默认隐藏二级类别 */}
    
    .pmHorizontalBottomOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        width:124px; /* 宽度 */
        height:auto; /* 高度 */
        margin:0px -2px 0px -2px; /* 外补丁 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .pmHorizontalBottomOut .level:hover .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level:hover .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
/*]]>*/
</style>
</head>
<body>
<p/><p/><p/><p/><p/>
<div class="pmHorizontalBottomOut" id="pmHorizontalBottomOut">
    <div class="level">
        <div class="levelTitle">level</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level&id=1">level_ title 1</a>
            <a href="?cat=level&id=2">level_ title 2</a>
            <a href="?cat=level&id=3">level_ title 3</a>
            <a href="?cat=level&id=4">level_ title 4</a>
            <a href="?cat=level&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 1</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_1&id=1">level_ title 1</a>
            <a href="?cat=level_1&id=2">level_ title 2</a>
            <a href="?cat=level_1&id=3">level_ title 3</a>
            <a href="?cat=level_1&id=4">level_ title 4</a>
            <a href="?cat=level_1&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 2</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_2&id=1">level_ title 1</a>
            <a href="?cat=level_2&id=2">level_ title 2</a>
            <a href="?cat=level_2&id=3">level_ title 3</a>
            <a href="?cat=level_2&id=4">level_ title 4</a>
            <a href="?cat=level_2&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 3</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_3&id=1">level_ title 1</a>
            <a href="?cat=level_3&id=2">level_ title 2</a>
            <a href="?cat=level_3&id=3">level_ title 3</a>
            <a href="?cat=level_3&id=4">level_ title 4</a>
            <a href="?cat=level_3&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 4</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_4&id=1">level_ title 1</a>
            <a href="?cat=level_4&id=2">level_ title 2</a>
            <a href="?cat=level_4&id=3">level_ title 3</a>
            <a href="?cat=level_4&id=4">level_ title 4</a>
            <a href="?cat=level_4&id=5">level_ title 5</a>
        </div>
    </div>
</div>
</body>
</html>
2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
linenum
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
" http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Untitled Document</title>
<style type="text/css">
/*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
    body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    /* ------------------- start 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    .pmHorizontalBottomOut{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    .pmHorizontalBottomOut .level{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 1px 0px 0px; /* 菜单外补丁间隔 */
        float:left;
    }
    .pmHorizontalBottomOut .level:hover { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level_{display:none; /* 默认隐藏二级类别 */}
    
    .pmHorizontalBottomOut .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        width:124px; /* 宽度 */
        height:auto; /* 高度 */
        margin:0px -2px 0px -2px; /* 外补丁 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .pmHorizontalBottomOut .level:hover .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level:hover .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .pmHorizontalBottomOut .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
    /* ------------------- end 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    
    /* ------------------- start 针对 IE 的 CSS 弹出菜单 -------------------*/
    .levelIe{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 1px 0px 0px; /* 菜单外补丁间隔 */
        float:left;
    }
    .levelIe { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .levelIe .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        width:124px; /* 宽度 */
        height:auto; /* 高度 */
        margin:0px -2px 0px -2px; /* 外补丁 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .levelIe .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
    /* ------------------- end 针对 IE 的 CSS 弹出菜单 -------------------*/
/*]]>*/
</style>
<script type="text/javascript">
//<![CDATA[
if (navigator.appName=="Microsoft Internet Explorer") {
    function fPmHorizontalBottomOut() {
        var getItem = document.getElementById("pmHorizontalBottomOut").getElementsByTagName("div");
        for (var i=0; i<getItem.length; i++) {
            getItem[i].onmouseover=function() { 
                if(    this.className=="level"){
                    this.className="levelIe";
                }
            }
            getItem[i].onmouseout=function() { 
                if(    this.className=="levelIe"){
                    this.className="level";
                }
            }//css popup menu script by shawl.qiu
        }
    }
    window.onload=fPmHorizontalBottomOut;
}
//]]>
</script>
</head>
<body>
<p/><p/><p/><p/><p/>
<div class="pmHorizontalBottomOut" id="pmHorizontalBottomOut">
    <div class="level">
        <div class="levelTitle">level</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level&id=1">level_ title 1</a>
            <a href="?cat=level&id=2">level_ title 2</a>
            <a href="?cat=level&id=3">level_ title 3</a>
            <a href="?cat=level&id=4">level_ title 4</a>
            <a href="?cat=level&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 1</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_1&id=1">level_ title 1</a>
            <a href="?cat=level_1&id=2">level_ title 2</a>
            <a href="?cat=level_1&id=3">level_ title 3</a>
            <a href="?cat=level_1&id=4">level_ title 4</a>
            <a href="?cat=level_1&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 2</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_2&id=1">level_ title 1</a>
            <a href="?cat=level_2&id=2">level_ title 2</a>
            <a href="?cat=level_2&id=3">level_ title 3</a>
            <a href="?cat=level_2&id=4">level_ title 4</a>
            <a href="?cat=level_2&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 3</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_3&id=1">level_ title 1</a>
            <a href="?cat=level_3&id=2">level_ title 2</a>
            <a href="?cat=level_3&id=3">level_ title 3</a>
            <a href="?cat=level_3&id=4">level_ title 4</a>
            <a href="?cat=level_3&id=5">level_ title 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">level 4</div>
        <div class="level_">
            <div class="level_title">level_ title</div>
            <a href="?cat=level_4&id=1">level_ title 1</a>
            <a href="?cat=level_4&id=2">level_ title 2</a>
            <a href="?cat=level_4&id=3">level_ title 3</a>
            <a href="?cat=level_4&id=4">level_ title 4</a>
            <a href="?cat=level_4&id=5">level_ title 5</a>
        </div>
    </div>
</div>
</body>
</html>

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

4. 预览

4.1 1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现) 的预览

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

4.2 2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现) 的预览

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

时间: 2024-11-03 15:12:01

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

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

css|菜单 编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu 摘要: 本文介绍了使用 CSS 编写适用于 Opera, Firefox, IE 的多风格弹出菜单 说明:编写 CSS 弹出菜单的要点不外乎当鼠标移到目标上时, 显示出隐藏的标签. 要隐藏的标签使用 display:none; 属性进行隐藏. 触发显示隐藏标签主要使用 :hover 属性, 并用 display:block; 显示隐藏的标签. 但由于浏览器对 CSS 的支持并非一致.对于 Opera 或者 Firefo

html5技术-CSS弹出菜单位置不精准问题

问题描述 CSS弹出菜单位置不精准问题 我做的这么一个鼠标移动到导航菜单上时弹出详细菜单,但是移动到上面也弹出啊,求大神指点,我实在不知道怎么办啊 解决方案 发代码前用</>格式化一下,要不显示不出来,不精准一般是样式有问题 解决方案二: 以下是我的代码.. <!DOCTYPE html> 123456 <pre><code>body ul a{ text-decoration:none;} body ul li{ display:inline; float

仅用css编写无限分级弹出菜单

css|菜单 一直以来,我们大多使用js来实现弹出菜单,可是根据 w3c 的css标准,根本就没有这个必要.只需要简单得使用css+html就可以做出一个无限分级的弹出菜单.没错,就是利用 Element:hover 这个伪类.注意,浏览这个例子,你必须使用标准浏览器,例如 Mozilla Firefox/ Opera 7.5 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.

不用script仅用css编写无限分级弹出菜单

css|菜单 一直以来,我们大多使用js来实现弹出菜单,可是根据 w3c 的css标准,根本就没有这个必要.只需要简单得使用css+html就可以做出一个无限分级的弹出菜单. 没错,就是利用 Element:hover 这个伪类. 注意,浏览这个例子,你必须使用标准浏览器,例如 Mozilla Firefox/ Opera 7.5 IE 不行!! <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http

完全css弹出菜单

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content

5款纯div+css制作的弹出菜单(标准且无js)

css|js|标准|菜单 一.最基本的:二级dropdown弹出菜单<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><

用css编写的适合标准浏览器的无限分级弹出菜单

css|标准|菜单|浏览器 一直以来,我们大多使用js来实现弹出菜单,可是根据 w3c 的css标准,根本就没有这个必要.只需要简单得使用css+html就可以做出一个无限分级的弹出菜单. 没错,就是利用 Element:hover 这个伪类. 注意,浏览这个例子,你必须使用标准浏览器,例如 Mozilla Firefox/ Opera 7.5 IE 不行!! <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" &qu

[Android] 底部菜单布局+PopupWindows实现弹出菜单功能(初级篇)

    这篇文章主要是自己研究如何对底部菜单进行布局,并简单的实现点击不同"按钮"实现图片切换和背景切换的功能,最后通过PopupWindows实现弹出菜单,点击不同按钮能实现不同方法,相当于美图秀秀编辑图片的功能吧!它并没有涉及到Fragment碎片切换页面的功能,因为页面始终显示被处理的图片.这是我初学Android的一篇基础性文章和在线思想笔记,网上有很多更优秀的demo,不过也希望对大家有用~     首先介绍两种方法实现底部菜单点击不同图标显示选中状态的效果.    (可参考

如何用Dreamweaver轻松制作弹出菜单

dreamweaver|菜单 本文选自4u2v工作室编写的<Dreamweaver网页设计与制作100例>(人民邮电出版社出版,ISBN: 7115142394 ).未经著作权所有者书面授权许可,禁止转载本文. 购买地址:点击访问 弹出菜单在网页制作中是一种非常常用的菜单方式,这种菜单不但制作简单,而且效果也很好. 效果说明 本实例所要完成的效果是当鼠标移动到文字上时,就会弹出一个漂亮的菜单,如图 17-1 和图 17-2 所示. 创作思想 本实例首先在网页中输入一行文字,并对文字做一个特殊的