Navs
Dokumentasjon og eksempler for hvordan du bruker Bootstraps medfølgende navigasjonskomponenter.
Basenav
Navigering tilgjengelig i Bootstrap deler generell markering og stiler, fra .nav
basisklassen til de aktive og deaktiverte tilstandene. Bytt modifikatorklasser for å bytte mellom hver stil.
Basekomponenten .nav
er bygget med flexbox og gir et sterkt grunnlag for å bygge alle typer navigasjonskomponenter. Den inkluderer noen stiloverstyringer (for å jobbe med lister), noe lenkepolstring for større treffområder og grunnleggende funksjonshemmede styling.
Basiskomponenten .nav
inkluderer ingen .active
tilstand. Følgende eksempler inkluderer klassen, hovedsakelig for å demonstrere at denne spesielle klassen ikke utløser noen spesiell styling.
Klassene brukes hele veien, så merkingen din kan være superfleksibel. Bruk <ul>
s som ovenfor, <ol>
hvis rekkefølgen på varene dine er viktig, eller rull din egen med et <nav>
element. Fordi .nav
brukerne display: flex
oppfører seg på samme måte som nav-elementer, men uten den ekstra markeringen.
Tilgjengelige stiler
Endre stilen til .nav
s-komponenten med modifikatorer og verktøy. Miks og match etter behov, eller bygg din egen.
Horisontal justering
Endre den horisontale justeringen av nav med flexbox-verktøy . Som standard er nav-er venstrejustert, men du kan enkelt endre dem til midt- eller høyrejustert.
Sentrert med .justify-content-center
:
Høyrejustert med .justify-content-end
:
Vertikal
Stable navigasjonen ved å endre retningen på flexelementet med .flex-column
verktøyet. Trenger du å stable dem på noen visningsporter, men ikke andre? Bruk de responsive versjonene (f.eks. .flex-sm-column
).
Som alltid er vertikal navigering også mulig uten <ul>
s.
Faner
Tar den grunnleggende navigasjonen ovenfra og legger til .nav-tabs
klassen for å generere et fanebasert grensesnitt. Bruk dem til å lage tabellområder med JavaScript-plugin-modulen vår .
Piller
Ta den samme HTML-en, men bruk .nav-pills
i stedet:
Fyll og begrunn
Tving .nav
innholdet ditt til å utvide den fulle tilgjengelige bredden en av to modifikasjonsklasser. For å fylle all tilgjengelig plass proporsjonalt med dine .nav-item
s, bruk .nav-fill
. Legg merke til at all horisontal plass er opptatt, men ikke alle nav-elementer har samme bredde.
Når du bruker en <nav>
-basert navigasjon, sørg for å inkludere .nav-item
på ankrene.
For elementer med lik bredde, bruk .nav-justified
. All horisontal plass vil bli okkupert av nav-lenker, men i motsetning til .nav-fill
ovennevnte vil hvert nav-element ha samme bredde.
I likhet med .nav-fill
eksempelet ved bruk av en <nav>
-basert navigasjon, sørg for å inkludere .nav-item
på ankrene.
Jobber med flexverktøy
Hvis du trenger responsive nav-varianter, bør du vurdere å bruke en rekke flexbox-verktøy . Selv om de er mer detaljerte, tilbyr disse verktøyene større tilpasning på tvers av responsive bruddpunkter. I eksemplet nedenfor vil nav-en vår bli stablet på det laveste bruddpunktet, og deretter tilpasses det til en horisontal layout som fyller den tilgjengelige bredden fra det lille bruddpunktet.
Angående tilgjengelighet
Hvis du bruker nav for å gi en navigasjonslinje, må du sørge for å legge til en role="navigation"
i den mest logiske overordnede beholderen til <ul>
, eller omslutte et <nav>
element rundt hele navigasjonen. Ikke legg rollen til seg <ul>
selv, da dette vil forhindre at den blir annonsert som en faktisk liste av hjelpeteknologier.
Merk at navigasjonslinjer, selv om de er visuelt stilte som faner med .nav-tabs
klassen, ikke skal gis role="tablist"
, role="tab"
eller role="tabpanel"
attributter. Disse er kun egnet for dynamiske fanebaserte grensesnitt, som beskrevet i WAI ARIA Authoring Practices . Se JavaScript-atferd for dynamiske fanebaserte grensesnitt i denne delen for et eksempel.
Bruker rullegardinmenyene
Legg til rullegardinmenyer med litt ekstra HTML og JavaScript-plugin-modulen .
Faner med rullegardiner
Piller med dropdowns
JavaScript-adferd
Bruk JavaScript-plugin-fanen – inkluder den individuelt eller gjennom den kompilerte bootstrap.js
filen – for å utvide våre navigasjonsfaner og piller for å lage tabulatorer med lokalt innhold, selv via rullegardinmenyer.
Hvis du bygger JavaScript fra kilden, kreverutil.js
det .
Dynamiske fanegrensesnitt, som beskrevet i WAI ARIA Authoring Practices , krever role="tablist"
, role="tab"
, role="tabpanel"
, og tilleggsattributter aria-
for å formidle deres struktur, funksjonalitet og nåværende tilstand til brukere av hjelpeteknologier (som skjermlesere).
Merk at dynamiske fanegrensesnitt ikke bør inneholde rullegardinmenyer, da dette forårsaker både brukervennlighet og tilgjengelighetsproblemer. Fra et brukervennlighetsperspektiv kan det faktum at utløserelementet til den aktuelle fanen som vises ikke er umiddelbart synlig (som det er inne i den lukkede rullegardinmenyen) forårsake forvirring. Fra et tilgjengelighetssynspunkt er det foreløpig ingen fornuftig måte å kartlegge denne typen konstruksjon til et standard WAI ARIA-mønster, noe som betyr at det ikke lett kan gjøres forståelig for brukere av hjelpemidler.
Rå denim du sannsynligvis ikke har hørt om dem jeanshorts Austin. Nesciunt tofu stumptown aliqua, retro synth master rens. Mustache cliche tempor, williamsburg carles vegan helvetica. Reprehenderit slakter retro keffiyeh dreamcatcher synth. Cosby genser eu banh mi, qui irure terry richardson ex squid. Aliquip placeat salvia cillum iphone. Seitan aliquip quis cardigan american apparel, slakter voluptate nisi qui.
Food truck fixie locavore, accusamus mcsweeney's marfa nulla single-origin coffee squid. Exercitation +1 labore velit, blog sartorial PBR leggings next level wes anderson artisan four loko farm-to-table craft beer twee. Qui photo booth letterpress, commodo enim craft beer mlkshk aliquip jean shorts ullamco ad vinyl cillum PBR. Homo nostrud organic, assumenda labore aesthetic magna delectus mollit. Keytar helvetica VHS salvia yr, vero magna velit sapiente labore stumptown. Vegan fanny pack odio cillum wes anderson 8-bit, sustainable jean shorts beard ut DIY ethical culpa terry richardson biodiesel. Art party scenester stumptown, tumblr butcher vero sint qui sapiente accusamus tattooed echo park.
Etsy mixtape wayfarers, ethical wes anderson tofu before they sold out mcsweeney's organic lomo retro fanny pack lo-fi farm-to-table readymade. Messenger bag gentrify pitchfork tattooed craft beer, iphone skateboard locavore carles etsy salvia banksy hoodie helvetica. DIY synth PBR banksy irony. Leggings gentrify squid 8-bit cred pitchfork. Williamsburg banh mi whatever gluten-free, carles pitchfork biodiesel fixie etsy retro mlkshk vice blog. Scenester cred you probably haven't heard of them, vinyl craft beer blog stumptown. Pitchfork sustainable tofu synth chambray yr.
For å hjelpe deg med å dekke dine behov, fungerer dette med <ul>
-basert markering, som vist ovenfor, eller med en hvilken som helst vilkårlig "rull din egen" markering. Vær oppmerksom på at hvis du bruker <nav>
, bør du ikke legge role="tablist"
direkte til den, da dette vil overstyre elementets opprinnelige rolle som navigasjonslandemerke. Bytt i stedet til et alternativt element (i eksemplet nedenfor, en enkel <div>
) og vikle <nav>
rundt det.
Tabs-pluginen fungerer også med piller.
Consequat occaecat ullamco amet non eiusmod nostrud dolore irure incididunt est duis anim sunt officia. Fugiat velit proident aliquip nisi incididunt nostrud exercitation proident est nisi. Irure magna elit commodo anim ex veniam culpa eiusmod id nostrud sit cupidatat in veniam ad. Eiusmod consequat eu adipisicing minim anim aliquip cupidatat culpa excepteur quis. Occaecat sit eu exercitation irure Lorem incididunt nostrud.
Ad pariatur nostrud pariatur exercitation ipsum ipsum culpa mollit commodo mollit ex. Aute sunt incididunt amet commodo est sint nisi deserunt pariatur do. Aliquip ex eiusmod voluptate exercitation cillum id incididunt elit sunt. Qui minim sit magna Lorem id et dolore velit Lorem amet exercitation duis deserunt. Anim id labore elit adipisicing ut in id occaecat pariatur ut ullamco ea tempor duis.
Est quis nulla laborum officia ad nisi ex nostrud culpa Lorem excepteur aliquip dolor aliqua irure ex. Nulla ut duis ipsum nisi elit fugiat commodo sunt reprehenderit laborum veniam eu veniam. Eiusmod minim exercitation fugiat irure ex labore incididunt do fugiat commodo aliquip sit id deserunt reprehenderit aliquip nostrud. Amet ex cupidatat excepteur aute veniam incididunt mollit cupidatat esse irure officia elit do ipsum ullamco Lorem. Ullamco ut ad minim do mollit labore ipsum laboris ipsum commodo sunt tempor enim incididunt. Commodo quis sunt dolore aliquip aute tempor irure magna enim minim reprehenderit. Ullamco consectetur culpa veniam sint cillum aliqua incididunt velit ullamco sunt ullamco quis quis commodo voluptate. Mollit nulla nostrud adipisicing aliqua cupidatat aliqua pariatur mollit voluptate voluptate consequat non.
Og med vertikale piller.
Cillum ad ut irure tempor velit nostrud occaecat ullamco aliqua anim Lorem sint. Veniam sint duis incididunt do esse magna mollit excepteur laborum qui. Id id reprehenderit sit est eu aliqua occaecat quis et velit excepteur laborum mollit dolore eiusmod. Ipsum dolor in occaecat commodo et voluptate minimal reprehenderit mollit pariatur. Deserunt non laborum enim et cillum eu deserunt excepteur ea incididunt minim occaecat.
Culpa dolor voluptate do laboris laboris irure reprehenderit id incididunt duis pariatur mollit aute magna pariatur consectetur. Eu veniam duis non ut dolor deserunt commodo et minim in quis laboris ipsum velit id veniam. Quis ut consectetur adipisicing officia excepteur non sit. Ut et elit aliquip labore Lorem enim eu. Ullamco mollit occaecat dolore ipsum id officia mollit qui esse anim eiusmod do sint minim consectetur qui.
Fugiat id quis dolor culpa eiusmod anim velit excepteur proident dolor aute qui magna. Ad proident laboris ullamco esse anim Lorem Lorem veniam quis Lorem irure occaecat velit nostrud magna nulla. Velit et et proident Lorem do ea tempor officia dolor. Reprehenderit Lorem aliquip labore est magna commodo est ea veniam consectetur.
Eu dolore ea ullamco dolore Lorem id cupidatat excepteur reprehenderit consectetur elit id dolor proident in cupidatat officia. Voluptate excepteur commodo labore nisi cillum duis aliqua do. Aliqua amet qui mollit consectetur nulla mollit velit aliqua veniam nisi id do Lorem deserunt amet. Culpa ullamco sit adipisicing labore officia magna elit nisi in aute tempor commodo eiusmod.
Bruk av dataattributter
Du kan aktivere en fane- eller pillenavigasjon uten å skrive noe JavaScript ved å spesifisere data-toggle="tab"
eller data-toggle="pill"
på et element. Bruk disse dataattributtene på .nav-tabs
eller .nav-pills
.
Via JavaScript
Aktiver tabbare faner via JavaScript (hver fane må aktiveres individuelt):
Du kan aktivere individuelle faner på flere måter:
Fade-effekt
To make tabs fade in, add .fade
to each .tab-pane
. The first tab pane must also have .show
to make the initial content visible.
Methods
Asynchronous methods and transitions
All API methods are asynchronous and start a transition. They return to the caller as soon as the transition is started but before it ends. In addition, a method call on a transitioning component will be ignored.
$().tab
Activates a tab element and content container. Tab should have either a data-target
or an href
targeting a container node in the DOM.
.tab(‘show’)
Selects the given tab and shows its associated pane. Any other tab that was previously selected becomes unselected and its associated pane is hidden. Returns to the caller before the tab pane has actually been shown (i.e. before the shown.bs.tab
event occurs).
.tab(‘dispose’)
Destroys an element’s tab.
Events
When showing a new tab, the events fire in the following order:
hide.bs.tab
(on the current active tab)show.bs.tab
(on the to-be-shown tab)hidden.bs.tab
(on the previous active tab, the same one as for thehide.bs.tab
event)shown.bs.tab
(on the newly-active just-shown tab, the same one as for theshow.bs.tab
event)
If no tab was already active, then the hide.bs.tab
and hidden.bs.tab
events will not be fired.
Event Type | Description |
---|---|
show.bs.tab | This event fires on tab show, but before the new tab has been shown. Use event.target and event.relatedTarget to target the active tab and the previous active tab (if available) respectively. |
shown.bs.tab | This event fires on tab show after a tab has been shown. Use event.target and event.relatedTarget to target the active tab and the previous active tab (if available) respectively. |
hide.bs.tab | This event fires when a new tab is to be shown (and thus the previous active tab is to be hidden). Use event.target and event.relatedTarget to target the current active tab and the new soon-to-be-active tab, respectively. |
hidden.bs.tab | This event fires after a new tab is shown (and thus the previous active tab is hidden). Use event.target and event.relatedTarget to target the previous active tab and the new active tab, respectively. |