Brak menu rozwijanego Bootstrap


324

Bootstrap 3 wciąż jest w wersji RC, ale właśnie próbowałem go zaimplementować. Nie mogłem wymyślić, jak umieścić klasę podmenu. Nawet nie ma klasy w css i nawet nowe dokumenty nic o tym nie mówią

Było tam w wersji 2.x z nazwą klasy jako podmenu


2
Pamiętaj, że niektóre elementy zmieniły się w wersji 3, w tym menu, nawigacje i moduły.
Deividi Cavarzan

11
brak natywnego wsparcia dla tej (imho) przydatnej funkcji w BS3 jest jednym z głównych powodów, dla których jeszcze się nie przestawiłem. chociaż zgadzam się, że nie jest tak przydatny w urządzeniach mobilnych, a teraz mają podejście „najpierw mobilne”, wydaje się, że krótkowzroczne jest usunięcie funkcji, którą już zaimplementowali, która jest BARDZO przydatna na komputerze
Andrew Brown

4
Zgodził się, że jest krótkowzroczny, aby usunąć oczekiwaną funkcjonalność. Tego rodzaju przełomowa zmiana daje deweloperom korporacyjnym zły dzień.
RJB

Aby utworzyć listę rozwijaną, użyj css codepen.io/Gothburz/pen/GpJKqP
Gothburz

Odpowiedzi:


555

Zaktualizowano 2018

dropdown-submenuZostała usunięta w Bootstrap 3 RC. Słowami autora Bootstrap, Marka Otto ..

„Podmenu po prostu nie mają teraz zbyt wiele miejsca w sieci, szczególnie mobilnej. Zostaną usunięte w wersji 3.0” - https://github.com/twbs/bootstrap/pull/6342

Ale przy odrobinie dodatkowego CSS możesz uzyskać tę samą funkcjonalność.

Bootstrap 4 (podmenu paska nawigacyjnego po najechaniu kursorem)

.navbar-nav li:hover > ul.dropdown-menu {
    display: block;
}
.dropdown-submenu {
    position:relative;
}
.dropdown-submenu>.dropdown-menu {
    top:0;
    left:100%;
    margin-top:-6px;
}

Wskaż menu rozwijane podmenu paska nawigacyjnego Wskaż menu rozwijane podmenu
paska nawigacyjnego (wyrównane do prawej)
Kliknij menu rozwijane podmenu paska nawigacyjnego (wyrównane do prawej)
Wskaż menu rozwijane paska nawigacyjnego (bez podmenu)


Bootstrap 3

Oto przykład, który używa wersji 3.0 RC 1: http://bootply.com/71520

Oto przykład wykorzystujący Bootstrap 3.0.0 (wersja ostateczna): http://bootply.com/86684

CSS

.dropdown-submenu {
    position:relative;
}
.dropdown-submenu>.dropdown-menu {
    top:0;
    left:100%;
    margin-top:-6px;
    margin-left:-1px;
    -webkit-border-radius:0 6px 6px 6px;
    -moz-border-radius:0 6px 6px 6px;
    border-radius:0 6px 6px 6px;
}
.dropdown-submenu:hover>.dropdown-menu {
    display:block;
}
.dropdown-submenu>a:after {
    display:block;
    content:" ";
    float:right;
    width:0;
    height:0;
    border-color:transparent;
    border-style:solid;
    border-width:5px 0 5px 5px;
    border-left-color:#cccccc;
    margin-top:5px;
    margin-right:-10px;
}
.dropdown-submenu:hover>a:after {
    border-left-color:#ffffff;
}
.dropdown-submenu.pull-left {
    float:none;
}
.dropdown-submenu.pull-left>.dropdown-menu {
    left:-100%;
    margin-left:10px;
    -webkit-border-radius:6px 0 6px 6px;
    -moz-border-radius:6px 0 6px 6px;
    border-radius:6px 0 6px 6px;
}

Próbka znaczników

<div class="navbar navbar-default navbar-fixed-top" role="navigation">
    <div class="container">
        <div class="navbar-header">
            <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-ex1-collapse">  
                <span class="sr-only">Toggle navigation</span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
            </button>
        </div>
        <div class="collapse navbar-collapse navbar-ex1-collapse">
            <ul class="nav navbar-nav">
                <li class="menu-item dropdown">
                    <a href="#" class="dropdown-toggle" data-toggle="dropdown">Drop Down<b class="caret"></b></a>
                    <ul class="dropdown-menu">
                        <li class="menu-item dropdown dropdown-submenu">
                            <a href="#" class="dropdown-toggle" data-toggle="dropdown">Level 1</a>
                            <ul class="dropdown-menu">
                                <li class="menu-item ">
                                    <a href="#">Link 1</a>
                                </li>
                                <li class="menu-item dropdown dropdown-submenu">
                                    <a href="#" class="dropdown-toggle" data-toggle="dropdown">Level 2</a>
                                    <ul class="dropdown-menu">
                                        <li>
                                            <a href="#">Link 3</a>
                                        </li>
                                    </ul>
                                </li>
                            </ul>
                        </li>
                    </ul>
                </li>
            </ul>
        </div>
    </div>
</div>

PS - Przykład w pasku nawigacyjnym, który dostosowuje lewą pozycję: http://bootply.com/92442


5
Tak, dziękuję. Dodałem go do arkusza stylów mojego motywu, po prostu skopiuj wklejony ze starej wersji bootstrap wordpress.org/themes/bikaner
DevC

8
Na przykład bootply.com/86684 , dodaj następujący wiersz w css dla poprawnego tła .dropdown-submenu:hover {background: #e2e1e1;}
kursora

1
Działa również z 3.1.1. Wielkie dzięki za rozwiązanie. Uderzyłem głową o ścianę, próbując zmienić plik bootstrap.js, aby działał poprawnie.
Joel Kinzel

2
Staram się maksymalnie uprościć sprawy, ale jest to potrzebne na dużych stronach internetowych bez możliwości poruszania się na wielu poziomach nawigacji (takich jak strony rządowe).
Troy Templeman,

1
Podmenu znika nawet zanim mogę do niego przesunąć mysz, więc najechanie myszą nie działa! Nie unosi się, polega na kliknięciu, ale działa OK.
Polv

61

Rozwiązanie @skelly jest dobre, ale nie działa na urządzeniach mobilnych, ponieważ stan najechania nie działa.

Dodałem trochę JS, aby przywrócić zachowanie BS 2.3.2.

PS: będzie działać z CSS, który tam znajdziesz: http://bootply.com/71520, chociaż możesz skomentować następującą część:

CSS:

/*.dropdown-submenu:hover>.dropdown-menu{display:block;}*/

JS:

$('ul.dropdown-menu [data-toggle=dropdown]').on('click', function(event) {
  // Avoid following the href location when clicking
  event.preventDefault();
  // Avoid having the menu to close when clicking
  event.stopPropagation();
  // If a menu is already open we close it
  $('ul.dropdown-menu [data-toggle=dropdown]').parent().removeClass('open');
  // opening the one you clicked on
  $(this).parent().addClass('open');
});

Wynik można znaleźć w moim motywie WordPress (u góry strony): http://shprinkone.julienrenaux.fr/


5
Jesteś najmądrzejszym facetem w tym poście
użytkownik1143669,

2
To rozwiązanie nie uwzględnia chęci zachowania funkcji aktywowania na komputerze stacjonarnym, a także nie działa w przypadku podmenu drugiego poziomu. Aby działało to dla większej liczby poziomów podmenu, zmień dwa ostatnie wiersze na następujący wiersz:, $(this).closest(".dropdown-submenu").toggleClass("open");który otworzy / zamknie elementy menu linków. Aby utrzymać wskaźnik myszy na pulpicie, konieczne jest sprawdzenie szerokości rzutni przeglądarki i będzie ona różna dla każdej witryny.
edhedges

dzięki za twój kod. ale w telefonie komórkowym twój kod ma błąd.
jian dan

42

Do dzisiaj (9 stycznia 2014 r.) Bootstrap 3 nadal nie obsługuje menu podmenu.

Szukałem w Google responsywnego menu nawigacyjnego i znalazłem to najlepsze.

To inteligentne menu http://www.smartmenus.org/

Mam nadzieję, że jest to wyjście dla każdego, kto chce menu nawigacji z wielopoziomowym podmenu.

aktualizacja 2015-02-17 Inteligentne menu w pełni obsługują styl elementu Bootstrap dla podmenu. Aby uzyskać więcej informacji, odwiedź witrynę Smart menu.


Miałem problem z próbowaniem najechania bootstrapem na hover na PC i kliknięcia na tablet z wieloma poziomami. Właśnie sprawiłeś, że mój dzień stał się lepszy! Działa pięknie - używa tego samego znacznika co bootstrap. Dziękuję Ci! :)
Hippie

2
To rozwiązanie jest bezpłatne, open source i działa bardzo dobrze z BootStrap 3.
Patrick Desjardins

5
Niesamowity! Łatwy! Szczegółowe informacje na temat integracji Bootstrap 3 można znaleźć tutaj: vadikom.github.io/smartmenus/src/demo/bootstrap-navbar.html
manafire

1
Smartmenus jest fajny, jednak działa tylko z paskami nawigacyjnymi, a nie z prostymi rozwijanymi przyciskami.
Nikolai Prokoschenko

1
uratowałeś mój projekt :-)
Sikander

5

Kod Shprink najbardziej mi pomógł, ale aby uniknąć rozwijania menu poza ekranem, zaktualizowałem go do:

JS:

$('ul.dropdown-menu [data-toggle=dropdown]').on('click', function(event) {
    // Avoid following the href location when clicking
    event.preventDefault(); 
    // Avoid having the menu to close when clicking
    event.stopPropagation(); 
    // If a menu is already open we close it
    $('ul.dropdown-menu [data-toggle=dropdown]').parent().removeClass('open');
    // opening the one you clicked on
    $(this).parent().addClass('open');

    var menu = $(this).parent().find("ul");
    var menupos = $(menu).offset();

    if (menupos.left + menu.width() > $(window).width()) {
        var newpos = -$(menu).width();
        menu.css({ left: newpos });    
    } else {
        var newpos = $(this).parent().width();
        menu.css({ left: newpos });
    }

});

CSS: OD koloru tła: #eeeeee DO koloru tła: # c5c5c5 - biała czcionka i jasne tło nie wyglądały dobrze.

.nav .open > a,
.nav .open > a:hover,
.nav .open > a:focus {
  background-color: #c5c5c5;
  border-color: #428bca;
}

Mam nadzieję, że to pomaga ludziom tak samo jak dla mnie!

Ale mam nadzieję, że Bootstrap ponownie doda funkcję subs z powrotem.



2

Kilka dni temu wpadłem na ten problem. Wypróbowałem wiele rozwiązań i żadne z nich tak naprawdę nie działało dla mnie, ale ostatecznie stworzyłem rozszerzenie / przesłonięcie rozwijanego kodu bootstrap. Jest to kopia oryginalnego kodu ze zmianami w funkcji closeMenus.

Myślę, że to dobre rozwiązanie, ponieważ nie wpływa na podstawowe klasy bootstrap js.

Możesz to sprawdzić na gihub: https://github.com/djokodonev/bootstrap-multilevel-dropdown


To bardzo dobre rozwiązanie dla rozwijanego menu wielopoziomowego, lubię go używać.
huncyrus

Cieszę się, że ci się podobało :-)
George Donev

-2

Tworzę inne rozwiązanie dla rozwijanego menu. Mam nadzieję, że to jest pomocne. Wystarczy dodać ten skrypt js

<script type="text/javascript"> jQuery("document").ready(function() {
  jQuery("ul.dropdown-menu > .dropdown.parent").click(function(e) {
    e.preventDefault();
    e.stopPropagation();
    if (jQuery(this).hasClass('open2'))
      jQuery(this).removeClass('open2');
    else {
      jQuery(this).addClass('open2');
    }

  });
}); < /script>

<style type="text/css">.open2{display:block; position:relative;}</style>
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.