Прокручиваемое многоуровневое горизонтальное меню

Я пытаюсь создать многоуровневое прокручиваемое горизонтальное меню . Подменю подходит хорошо до уровня n, но полоса прокрутки не появляется, когда количество элементов верхнего уровня li больше и не может соответствовать странице. Вместо этого они начинают приходить в следующей строке.

Ниже приведен полный код

<html>
	<head>
	<style type="text/css">

   

	#nav, #nav ul{
margin:0;
padding:0;
list-style-type:none;
list-style-position:outside;
position:relative;
line-height:1.5em; 
}

#nav a{
display:block;
padding:0px 5px;
border:1px solid #333;
color:#fff;
text-decoration:none;
background-color:#333;
}

#nav a:hover{
background-color:#fff;
color:#333;
}

#nav li{
float:left;
position:relative;
}

#nav ul {
position:absolute;
display:none;
width:12em;
top:1.5em;
}

#nav li ul a{
width:12em;
height:auto;
float:left;
}

#nav ul ul{
top:auto;
}	

#nav li ul ul {
left:12em;
margin:0px 0 0 10px;
}

#nav li:hover ul ul, #nav li:hover ul ul ul, #nav li:hover ul ul ul ul{
display:none;
}
#nav li:hover ul, #nav li li:hover ul, #nav li li li:hover ul, #nav li li li li:hover ul{
display:block;
}




	</style>		
	</head>
	<body>
          <ul id="nav">
                <li>
                    <a href="#">3 Javascript</a>
                    <ul>
                        <li>
                            <a href="#">3.1 jQuery</a>
                            <ul>
                                <li>
                                    <a href="#">3.1.1 Download</a>
                                    <ul>
                                        <li>
                                            <a href="#">3.1.1 New Download</a>

                                        </li>
                                        <li><a href="#">3.1.2 New Tutorial</a></li>
                                    </ul>
                                </li>
                                <li><a href="#">3.1.2 Tutorial</a></li>
                            </ul>
                        </li>
                        <li><a href="#">3.2 Mootools</a></li>
                        <li><a href="#">3.3 Prototype</a></li>
                    </ul>
                </li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>

                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>
                <li><a href="#">1 HTML</a></li>
                <li><a href="#">2 CSS</a></li>




         
            </ul>
     




</body>
</html>

2 ответа

  1. <html>
    	<head>
    	<style type="text/css">
    
       
    
    	#nav, #nav ul{
    margin:0;
    padding:0;
    list-style-type:none;
    list-style-position:outside;
    position:relative;
    line-height:1.5em; 
    width: 100%;
    overflow-x: scroll;
    white-space: nowrap;
    }
    
    #nav a{
    display:block;
    padding:0px 5px;
    border:1px solid #333;
    color:#fff;
    text-decoration:none;
    background-color:#333;
    }
    
    #nav a:hover{
    background-color:#fff;
    color:#333;
    }
    
    #nav li{
    display: inline-block;
    position:relative;
    }
    
    #nav ul {
    position:absolute;
    display:none;
    width:12em;
    top:1.5em;
    }
    
    #nav li ul a{
    width:12em;
    height:auto;
    float:left;
    }
    
    #nav ul ul{
    top:auto;
    }	
    
    #nav li ul ul {
    left:12em;
    margin:0px 0 0 10px;
    }
    
    #nav li:hover ul ul, #nav li:hover ul ul ul, #nav li:hover ul ul ul ul{
    display:none;
    }
    #nav li:hover ul, #nav li li:hover ul, #nav li li li:hover ul, #nav li li li li:hover ul{
    display:block;
    }
    
    
    
    
    	</style>		
    	</head>
    	<body>
              <ul id="nav">
                    <li>
                        <a href="#">3 Javascript</a>
                        <ul>
                            <li>
                                <a href="#">3.1 jQuery</a>
                                <ul>
                                    <li>
                                        <a href="#">3.1.1 Download</a>
                                        <ul>
                                            <li>
                                                <a href="#">3.1.1 New Download</a>
    
                                            </li>
                                            <li><a href="#">3.1.2 New Tutorial</a></li>
                                        </ul>
                                    </li>
                                    <li><a href="#">3.1.2 Tutorial</a></li>
                                </ul>
                            </li>
                            <li><a href="#">3.2 Mootools</a></li>
                            <li><a href="#">3.3 Prototype</a></li>
                        </ul>
                    </li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
    
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
                    <li><a href="#">1 HTML</a></li>
                    <li><a href="#">2 CSS</a></li>
    
    
    
    
             
                </ul>
         
    
    
    
    
    </body>
    </html>

    это то, чего вы хотите достичь?

  2. Предыдущий ответ не объясняет должным образом, каким было фактическое решение кода. Хотя код правильный. Я хотел бы отметить, что это, скорее всего, проблема высоты в «nav» div. Вы не должны ставить высоту на авто. Но вместо этого держите его фиксированным, чтобы браузер прокручивал остальное. Вы также можете попробовать стиль «overflow», чтобы установить прокрутку, если список больше ширины.