二级菜单实现

今天来根据之前写的move函数写一个二级菜单

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>二级菜单</title>
        <style type="text/css">
            * {
                margin: 0;
                padding: 0;
                list-style-type: none;
            }
            
            a,img {
                border: 0;
                text-decoration: none;
            }
            
            body {
                font: 12px/180% Arial, Helvetica, sans-serif, "新宋体";
            }
        </style>

        <link rel="stylesheet" type="text/css" href="css/sdmenu.css" />
        
        <script type="text/javascript" src="js/tools.js"></script>
        <script type="text/javascript">
            window.onload = function(){
                
                /*
                 * 我们的每一个菜单都是一个div
                 *     当div具有collapsed这个类时,div就是折叠的状态
                 *     当div没有这个类是,div就是展开的状态
                 */
                
                /*
                 * 点击菜单,切换菜单的显示状态
                 */
                //获取所有的class为menuSpan的元素
                var menuSpan = document.querySelectorAll(".menuSpan");
                
                //定义一个变量,来保存当前打开的菜单
                var openDiv = menuSpan[0].parentNode;
                
                //为span绑定单击响应函数
                for(var i=0 ; i<menuSpan.length ; i++){
                    menuSpan[i].onclick = function(){
                        
                        //this代表我当前点击的span
                        //获取当前span的父元素
                        var parentDiv = this.parentNode;
                        
                        //切换菜单的显示状态
                        toggleMenu(parentDiv);
                        
                        
                        //判断openDiv和parentDiv是否相同
                        if(openDiv != parentDiv  && !hasClass(openDiv , "collapsed")){
                            //打开菜单以后,应该关闭之前打开的菜单
                            //为了可以统一处理动画过渡效果,我们希望在这将addClass改为toggleClass
                            //addClass(openDiv , "collapsed");s
                            //此处toggleClass()不需要有移除的功能
                            //toggleClass(openDiv , "collapsed");
                            //切换菜单的显示状态
                            toggleMenu(openDiv);
                        }
                        
                        //修改openDiv为当前打开的菜单
                        openDiv = parentDiv;
                        
                    };
                }
                
                /*
                 * 用来切换菜单折叠和显示状态
                 */
                function toggleMenu(obj){
                    //在切换类之前,获取元素的高度
                    var begin = obj.offsetHeight;
                    
                    //切换parentDiv的显示
                    toggleClass(obj , "collapsed");
                    
                    //在切换类之后获取一个高度
                    var end = obj.offsetHeight;
                    
                    //console.log("begin = "+begin +" , end = "+end);
                    //动画效果就是将高度从begin向end过渡
                    //将元素的高度重置为begin
                    obj.style.height = begin + "px";
                    
                    //执行动画,从bengin向end过渡
                    move(obj,"height",end,10,function(){
                        //动画执行完毕,内联样式已经没有存在的意义了,删除之
                        obj.style.height = "";
                    });
                        
                }
                
                
            };
            
            
        </script>
        
    </head>

    <body>

        <div id="my_menu" class="sdmenu">
            <div>
                <span class="menuSpan">在线工具</span>
                <a href="#">图像优化</a>
                <a href="#">收藏夹图标生成器</a>
                <a href="#">邮件</a>
                <a href="#">htaccess密码</a>
                <a href="#">梯度图像</a>
                <a href="#">按钮生成器</a>
            </div>
            <div class="collapsed">
                <span class="menuSpan">支持我们</span>
                <a href="#">推荐我们</a>
                <a href="#">链接我们</a>
                <a href="#">网络资源</a>
            </div>
            <div class="collapsed">
                <span class="menuSpan">合作伙伴</span>
                <a href="#">JavaScript工具包</a>
                <a href="#">CSS驱动</a>
                <a href="#">CodingForums</a>
                <a href="#">CSS例子</a>
            </div>
            <div class="collapsed">
                <span class="menuSpan">测试电流</span>
                <a href="#">Current or not</a>
                <a href="#">Current or not</a>
                <a href="#">Current or not</a>
                <a href="#">Current or not</a>
            </div>
        </div>
    </body>
</html>

 css代码:

@charset "utf-8";

/* sdmenu */

div.sdmenu {
    width: 150px;
    margin: 0 auto;
    font-family: Arial, sans-serif;
    font-size: 12px;
    padding-bottom: 10px;
    background: url(bottom.gif) no-repeat right bottom;
    color: #fff;
    
}

div.sdmenu div {
    background: url(title.gif) repeat-x;
    overflow: hidden;
}

div.sdmenu div:first-child {
    background: url(toptitle.gif) no-repeat;
}

div.sdmenu div.collapsed {
    height: 25px;
}

div.sdmenu div span {
    display: block;
    height: 15px;
    line-height: 15px;
    overflow: hidden;
    padding: 5px 25px;
    font-weight: bold;
    color: white;
    background: url(expanded.gif) no-repeat 10px center;
    cursor: pointer;
    border-bottom: 1px solid #ddd;
}

div.sdmenu div.collapsed span {
    background-image: url(collapsed.gif);
}

div.sdmenu div a {
    padding: 5px 10px;
    background: #eee;
    display: block;
    border-bottom: 1px solid #ddd;
    color: #066;
}

div.sdmenu div a.current {
    background: #ccc;
}

div.sdmenu div a:hover {
    background: #066 url(linkarrow.gif) no-repeat right center;
    color: #fff;
    text-decoration: none;
}

猜你喜欢

转载自www.cnblogs.com/caicaihong/p/9360902.html