导航菜单特效-三级联动导航菜单

————————————————————————

<script type="text/javascript">
            var arr = [];    //定义数据数组变量
            //为菜单指定数据,包含了名字和URL
            arr[0] = [{name:'菜单1',url:'#'},{name:'菜单11',url:'#'}];
            arr[1] = [{name:'菜单2',url:'#'}];
            arr[2] = [{name:'菜单3',url:'#'},{name:'菜单31',url:'#'},
                {name:'菜单32',url:'#',child:[
                    {name:'菜单321',url:'#'}
                ]}];            //包含了子菜单
            //在jquery的加载回调函数里操作
            $(function(){
                //定义菜单的html内容,以ul打头
                var html = '<ul class="menu clearfix">';
                //根据数组变量的长度,开始串联第一级菜单
                for(var i=0;i<arr.length;i++){
                    html += '<li><a href="#">菜单'+(i+1)+'</a></li>';
                }
                html += '</ul>';
                //第一级菜单组合完成
                //开始组合二级菜单
                html += '<div class="sub_div clearfix">';
                //使用两次循环开始串联第二级菜单
                for(var i=0;i<arr.length;i++){
                    var a = arr[i];                    //得到当前的数据
                    html += '<ul class="sub_menu">';//拼接二级菜单项
                    var sub_count = 1;                //开始计数id
                    for(var j=0;j<a.length;j++){    //遍历
                        var item = a[j];            //得到数据
                        var sub = '';                //定义拼接有子菜单的class属性
                        if(item['child'])            //如果包含了子属性,则定义class
                            sub = 'sub sub_'+j+'_'+sub_count++;
                        //拼接动态的第二级菜单的字符
                        html += '<li><a href="'+item['url']+'" class="+sub+" index="'+j+'">'+item['name']+'</a></li>';
                    }
                    html += '</ul>';                //完成第二级菜单
                    var sub_count = 1;                //开始为三级菜单的id计数
                    for(var j=0;j<a.length;j++){    //遍历第三级菜单
                        var item = a[j];            //得到数据
                        if(item['child']){            //如果包含三级菜单
                            var b = item['child'];    //得到子菜单项的数据
                            //拼接第三层的字符
                            html += '<ul class="third_menu" id="'+'sub_'+j+'_'+sub_count+++'">';
                            //遍历第三层的数据变量
                            for(var k=0;k<b.length;k++){
                                html += '<li><a href="'+b[k]['url']+'">'+b[k]['name']+'</a></li>';
                            }
                            html += '</ul>';        //完成第三层
                        }
                    }
                }
                html += '</div>';                    //完成全部的菜单html
                $('body').append(html);                //挂接在body里        
                
                var menus = $('.menu a');        //得到菜单下所有的链接
                for(var i=0;i<menus.length;i++){//遍历这些链接
                    var m = menus[i];            //得到当前的链接
                    $(m).mouseover(function(){    //为菜单链接定义onmouover事件
                        //得到当前鼠标移入的菜单项的下标
                        var index = $('.menu a').index(this);
                        $('.sub_menu').hide();    //把其他二级菜单隐藏
                        $('.third_menu').hide();//三级也隐藏
                        $('.sub_menu').eq(index).show();//显示对应的二级菜单
                        //计算二级菜单应该定位的位置
                        $('.sub_menu').eq(index).css('margin-left',(100*index)+'px');
                    });
                }
                //为包含第三级菜单的二级菜单定义onmouseover事件
                $('.sub').mouseover(function(){
                    //得到它的class属性
                    var className = $(this).attr('class');
                    //得到第三级菜单的id值
                    var subId = className.split(' ')[1];
                    $('#'+subId).show();        //显示第三级菜单
                    var index = $(this).attr('index');//得到它的下标
                    //计算第三级菜单显示的坐标位置
                    $('#'+subId).css('margin-top',(parseInt(index)*20)+'px');
                });
            });
        </script>

——————————————————————

<style>
            .menu{
                list-style: none;
                width: 500px;
                margin: 10px auto 0;
                padding:0;
            }
            .menu li{
                float:left;
                width:98px;
                border:1px solid black;
            }
            .menu a{
                color:black;
                width:100%;
            }
            .menu a:hover{
                background-color:pink;
            }
            .clearfix:after {
                visibility: hidden;
                display: block;
                font-size: 0;
                content: " ";
                clear: both;
                height: 0;
            }
            .sub_menu{
                border:1px solid black;
                width: 100px;
                padding:0;
                display: none;
                margin:0;
                float:left;
            }
            .sub_div{
                width: 505px;
                margin: 0 auto;
            }
            .third_menu{
                display:none;
                float: left;
                border:1px solid black;
                width: 100px;
                padding:0;
                margin:0;
            }
        </style>

————————————————————————————

<body style="text-align:center">
        
    </body>

————————————————————————————

posted @ 2016-09-29 11:00  承载梦想-韩旭明  阅读(1199)  评论(0编辑  收藏  举报