En utilisant Bootstrap 3, j'ai besoin de construire un menu vertical contenant des sous-menus à bascule. J'ai la structure suivante:
<nav>
<ul>
<li><a href="#">Item 1</a></li>
<li><a href="#">Item 2 (toggle)</a>
<ul>
<li><a href="#">Item 2.1</a></li>
<li><a href="#">Item 2.2</a></li>
<li><a href="#">Item 2.3</a></li>
</ul>
</li>
<li><a href="#">Item 3</a></li>
<li><a href="#">Item 4</a></li>
</ul>
</nav>
Je veux que l'UL à l'intérieur de "Item 2" soit caché par défaut et le dévoile/cache en appuyant sur "Item 2".
La clé pour faire basculer un sous-menu vertical est d'utiliser l'attribut data-toggle = "collapse" au lieu du plus commun utilisé dans les navs data-toggle = "dropdown".
J'ai préparé ceci exemple jsfiddle , et voici le code wordking:
<nav>
<ul class="nav">
<li><a href="#">Link 1</a></li>
<li><a href="#" id="btn-1" data-toggle="collapse" data-target="#submenu1" aria-expanded="false">Link 2 (toggle)</a>
<ul class="nav collapse" id="submenu1" role="menu" aria-labelledby="btn-1">
<li><a href="#">Link 2.1</a></li>
<li><a href="#">Link 2.2</a></li>
<li><a href="#">Link 2.3</a></li>
</ul>
</li>
<li><a href="#">Link 3</a></li>
<li><a href="#">Link 4</a></li>
</ul>
</nav>
Parfois, vous avez besoin à la fois d'un lien d'élément de menu et d'une bascule pour les éléments de sous-menu.
Voici un test:
/* CSS */
.toggle-custom {
position: absolute !important;
top: 0;
right: 0;
}
.toggle-custom[aria-expanded='true'] .glyphicon-plus:before {
content: "\2212";
}
<link href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.1/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://code.jquery.com/jquery-1.11.1.min.js" type="text/javascript" ></script>
<script src="//maxcdn.bootstrapcdn.com/bootstrap/3.3.1/js/bootstrap.min.js" type="text/javascript" ></script>
<nav>
<ul class="nav">
<li><a href="#">Link 1</a>
</li>
<li><a href="#">Link 2</a><a href="#" class="toggle-custom" id="btn-1" data-toggle="collapse" data-target="#submenu1" aria-expanded="false"><span class="glyphicon glyphicon-plus" aria-hidden="true"></span></a>
<ul class="nav collapse" id="submenu1" role="menu" aria-labelledby="btn-1">
<li><a href="#">Link 2.1</a>
</li>
<li><a href="#">Link 2.2</a>
</li>
<li><a href="#">Link 2.3</a>
</li>
</ul>
</li>
<li><a href="#">Link 3</a>
</li>
</ul>
</nav>