Rippmenüüd
Lülitage kontekstipõhiseid ülekatteid linkide loendite ja muu kuvamiseks Bootstrapi rippmenüü pistikprogrammiga.
Rippmenüüd on vahetatavad, kontekstipõhised ülekatted linkide loendite kuvamiseks ja palju muud. Need on interaktiivsed kaasasoleva Bootstrapi rippmenüü JavaScripti pistikprogrammiga. Neid vahetatakse klõpsates, mitte hõljutades; see on tahtlik disainiotsus.
Rippmenüüd on üles ehitatud kolmanda osapoole teegile Popper.js , mis pakub dünaamilist positsioneerimist ja vaateava tuvastamist. Lisage kindlasti enne Bootstrapi JavaScripti popper.min.js või kasutage /bootstrap.bundle.min.js
mis bootstrap.bundle.js
sisaldab Popper.js-i. Popper.js-i ei kasutata navigeerimisribade rippmenüüde positsioneerimiseks, kuna dünaamiline positsioneerimine pole vajalik.
Kui loote meie JavaScripti allikast, nõuabutil.js
see .
WAI ARIA standard määratleb tegeliku vidinarole="menu"
, kuid see on spetsiifiline rakenduslike menüüde jaoks, mis käivitavad toiminguid või funktsioone. ARIA menüüd võivad sisaldada ainult menüüüksusi, märkeruutude menüüüksusi, raadionuppude menüüüksusi, raadionupurühmi ja alammenüüsid.
Bootstrapi rippmenüüd on seevastu loodud üldiseks ja rakendatavaks mitmesugustes olukordades ja märgistusstruktuurides. Näiteks on võimalik luua rippmenüüd, mis sisaldavad täiendavaid sisendeid ja vormi juhtelemente, nagu otsinguvälju või sisselogimisvorme. Sel põhjusel ei oota Bootstrap (ega lisa automaatselt) ühtegi tõelise ARIA menüü jaoks vajalikke atribuute role
ja . Autorid peavad need täpsemad atribuudid ise lisama.aria-
Siiski lisab Bootstrap sisseehitatud toe enamiku standardsete klaviatuurimenüü interaktsioonide jaoks, nagu näiteks võimalus .dropdown-item
kursoriklahvide abil üksikute elementide vahel liikuda ja klahviga menüü sulgeda ESC.
Pakkige rippmenüü lüliti (oma nupp või link) ja rippmenüü sisse .dropdown
või muusse elemendisse, mis deklareerib position: relative;
. Rippmenüüd saab käivitada <a>
või <button>
elementidest, et need vastaksid paremini teie potentsiaalsetele vajadustele.
Mis tahes singlit .btn
saab mõne märgistuse muudatusega muuta rippmenüü lülitiks. Siin on, kuidas saate neid mõlema <button>
elemendiga tööle panna.
<div class="dropdown">
<button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown button
</button>
<div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
</div>
</div>
Ja <a>
elementidega:
<div class="dropdown show">
<a class="btn btn-secondary dropdown-toggle" href="#" role="button" id="dropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown link
</a>
<div class="dropdown-menu" aria-labelledby="dropdownMenuLink">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
</div>
</div>
Parim osa on see, et saate seda teha ka mis tahes nupu variandiga:
Sarnaselt looge jagatud nuppude rippmenüüd, millel on peaaegu sama märgistus kui ühe nupu rippmenüüd, kuid lisades .dropdown-toggle-split
rippmenüü tähise ümber õige vahekauguse.
Kasutame seda lisaklassi, et vähendada horisontaali padding
mõlemal küljel 25% ja eemaldada margin-left
tavaliste nuppude rippmenüüde jaoks lisatud. Need lisamuudatused hoiavad tähise jaotusnupu keskel ja pakuvad põhinupu kõrval sobivama suurusega löögiala.
Nuppude rippmenüüd töötavad igas suuruses nuppudega, sealhulgas vaike- ja jagatud rippmenüü nuppudega.
Käivitage rippmenüüd elementide kohal, lisades .dropup
need emaelemendile.
Käivitage rippmenüüd elementide paremal, lisades .dropright
need emaelemendile.
Käivitage elementide vasakul rippmenüüd, lisades .dropleft
need emaelemendile.
Ajalooliselt pidi rippmenüü sisu olema lingid, kuid versiooni 4 puhul see enam nii ei kehti. Nüüd saate valikuliselt kasutada <button>
rippmenüüdes elemente, mitte ainult <a>
s.
<div class="dropdown">
<button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenu2" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown
</button>
<div class="dropdown-menu" aria-labelledby="dropdownMenu2">
<button class="dropdown-item" type="button">Action</button>
<button class="dropdown-item" type="button">Another action</button>
<button class="dropdown-item" type="button">Something else here</button>
</div>
</div>
Vaikimisi positsioneeritakse rippmenüü automaatselt 100% ülaosast ja vanema vasakust servast. Rippmenüü lisamine paremale joondamiseks .dropdown-menu-right
..dropdown-menu
Pea püsti! Rippmenüüd on paigutatud tänu Popper.js-ile (välja arvatud juhul, kui need sisalduvad navigeerimisribal).
<div class="btn-group">
<button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Right-aligned menu
</button>
<div class="dropdown-menu dropdown-menu-right">
<button class="dropdown-item" type="button">Action</button>
<button class="dropdown-item" type="button">Another action</button>
<button class="dropdown-item" type="button">Something else here</button>
</div>
</div>
Lisage päis mis tahes rippmenüü tegevuste jaotistele.
<div class="dropdown-menu">
<h6 class="dropdown-header">Dropdown header</h6>
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
</div>
Eraldage seotud menüüelementide rühmad jaguriga.
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="#">Separated link</a>
</div>
Pange vorm rippmenüüsse või muutke see rippmenüüks ja kasutage veerise või polsterduse utiliite , et anda sellele vajalik negatiivne ruum.
<div class="dropdown-menu">
<form class="px-4 py-3">
<div class="form-group">
<label for="exampleDropdownFormEmail1">Email address</label>
<input type="email" class="form-control" id="exampleDropdownFormEmail1" placeholder="[email protected]">
</div>
<div class="form-group">
<label for="exampleDropdownFormPassword1">Password</label>
<input type="password" class="form-control" id="exampleDropdownFormPassword1" placeholder="Password">
</div>
<div class="form-check">
<input type="checkbox" class="form-check-input" id="dropdownCheck">
<label class="form-check-label" for="dropdownCheck">
Remember me
</label>
</div>
<button type="submit" class="btn btn-primary">Sign in</button>
</form>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="#">New around here? Sign up</a>
<a class="dropdown-item" href="#">Forgot password?</a>
</div>
<form class="dropdown-menu p-4">
<div class="form-group">
<label for="exampleDropdownFormEmail2">Email address</label>
<input type="email" class="form-control" id="exampleDropdownFormEmail2" placeholder="[email protected]">
</div>
<div class="form-group">
<label for="exampleDropdownFormPassword2">Password</label>
<input type="password" class="form-control" id="exampleDropdownFormPassword2" placeholder="Password">
</div>
<div class="form-check">
<input type="checkbox" class="form-check-input" id="dropdownCheck2">
<label class="form-check-label" for="dropdownCheck2">
Remember me
</label>
</div>
<button type="submit" class="btn btn-primary">Sign in</button>
</form>
Lisage .active
rippmenüü üksustele, et kujundada need aktiivseteks .
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Regular link</a>
<a class="dropdown-item active" href="#">Active link</a>
<a class="dropdown-item" href="#">Another link</a>
</div>
Lisage .disabled
rippmenüüs olevatele üksustele, et kujundada need keelatuks .
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Regular link</a>
<a class="dropdown-item disabled" href="#">Disabled link</a>
<a class="dropdown-item" href="#">Another link</a>
</div>
Andmeatribuutide või JavaScripti kaudu lülitab rippmenüü pistikprogramm peidetud sisu (rippmenüüd) sisse, lülitades .show
klassi ülemloendi üksusel. Atribuuti data-toggle="dropdown"
kasutatakse rakenduse tasemel rippmenüüde sulgemisel, seega on hea mõte seda alati kasutada.
Puutetundlike seadmete puhul lisab rippmenüü avamine elemendi vahetutele alamatele tühjad ( $.noop
) töötlejad. See ilmselt inetu häkkimine on vajalik iOS-i sündmuste delegeerimise veidruse ületamiseks, mis muidu takistaks rippmenüüst väljaspool asuvat puudutust käivitamast rippmenüü sulgevat koodi. Kui rippmenüü suletakse, eemaldatakse need täiendavad tühjad käitlejad.mouseover
<body>
mouseover
Lisage data-toggle="dropdown"
lingile või nupule rippmenüü sisselülitamiseks.
Kutsuge rippmenüüd JavaScripti kaudu:
data-toggle="dropdown"
ikka nõutud
Olenemata sellest, kas helistate rippmenüüsse JavaScripti kaudu või kasutate selle asemel andmeapi-d, data-toggle="dropdown"
peab rippmenüü päästikuelemendil alati olema.
Valikud saab edastada andmeatribuutide või JavaScripti kaudu. Andmeatribuutide jaoks lisage valiku nimi data-
, nagu data-offset=""
.
Nimi | Tüüp | Vaikimisi | Kirjeldus |
---|---|---|---|
nihe | number | string | funktsiooni | 0 | Rippmenüü nihe sihtmärgi suhtes. Lisateabe saamiseks vaadake Popper.js'i nihkedokumente . |
klapp | tõeväärtus | tõsi | Luba rippmenüül ümber pöörata, kui võrdluselement kattub. Lisateabe saamiseks vaadake Popper.js'i flip-dokumente . |
piiri | string | element | 'scrollParent' | Rippmenüü ülevoolupiirangu piir. Aktsepteerib 'viewport' , 'window' , 'scrollParent' , või HTMLElementi viite väärtusi (ainult JavaScript). Lisateabe saamiseks vaadake Popper.js'i preventOverflow dokumente . |
Pange tähele, kui boundary
väärtuseks on määratud mis tahes muu väärtus peale , rakendatakse 'scrollParent'
stiil konteinerile.position: static
.dropdown
meetod | Kirjeldus |
---|---|
$().dropdown('toggle') |
Lülitab antud navigeerimisriba või vahelehtedega navigeerimise rippmenüü sisse- ja väljalülitamiseks. |
$().dropdown('update') |
Värskendab elemendi rippmenüü asukohta. |
$().dropdown('dispose') |
Hävitab elemendi rippmenüü. |
Kõik rippmenüü sündmused käivitatakse .dropdown-menu
ülemelemendis ja neil on relatedTarget
atribuut, mille väärtus on lülitusankurelement.
Sündmus | Kirjeldus |
---|---|
show.bs.dropdown |
See sündmus käivitub kohe, kui kutsutakse näitamise eksemplari meetod. |
shown.bs.dropdown |
See sündmus käivitatakse, kui rippmenüü on kasutajale nähtavaks tehtud (ootab CSS-i üleminekuid, et lõpetada). |
hide.bs.dropdown |
See sündmus käivitatakse kohe, kui peida eksemplari meetod on välja kutsutud. |
hidden.bs.dropdown |
See sündmus käivitatakse, kui rippmenüü on kasutaja eest peitmise lõpetanud (ootab CSS-i üleminekuid, et lõpetada). |