Gereedskapwenke
Dokumentasie en voorbeelde vir die byvoeging van pasgemaakte Bootstrap-nutsmiddelwenke met CSS en JavaScript met behulp van CSS3 vir animasies en data-bs-kenmerke vir plaaslike titelberging.
Oorsig
Dinge om te weet wanneer jy die tooltip-inprop gebruik:
- Gereedskapwenke maak staat op die derdeparty-biblioteek Popper vir posisionering. Jy moet popper.min.js voor bootstrap.js insluit of
bootstrap.bundle.min.js
/bootstrap.bundle.js
wat Popper bevat gebruik sodat gereedskapwenke kan werk! - Gereedskapwenke is intekening vir prestasieredes, so jy moet dit self inisialiseer .
- Gereedskapwenke met titels van geen lengte word nooit vertoon nie.
- Spesifiseer
container: 'body'
om te verhoed dat probleme in meer komplekse komponente weergegee word (soos ons invoergroepe, knoppiegroepe, ens.). - Om gereedskapwenke op verborge elemente te aktiveer, sal nie werk nie.
- Gereedskapwenke vir
.disabled
ofdisabled
elemente moet op 'n omhulelement geaktiveer word. - Wanneer dit geaktiveer word vanaf hiperskakels wat oor verskeie lyne strek, sal gereedskapwenke gesentreer word. Gebruik
white-space: nowrap;
op jou<a>
s om hierdie gedrag te vermy. - Gereedskapwenke moet versteek word voordat hul ooreenstemmende elemente uit die DOM verwyder is.
- Gereedskapwenke kan geaktiveer word danksy 'n element binne 'n skadu-DOM.
prefers-reduced-motion
medianavraag. Sien die
verminderde beweging-afdeling van ons toeganklikheidsdokumentasie .
Het jy dit alles? Wonderlik, kom ons kyk hoe hulle werk met 'n paar voorbeelde.
Voorbeeld: Aktiveer gereedskapwenke oral
Een manier om alle gereedskapwenke op 'n bladsy te inisialiseer, is om hulle volgens hul data-bs-toggle
kenmerk te kies:
var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'))
var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
return new bootstrap.Tooltip(tooltipTriggerEl)
})
Voorbeelde
Beweeg oor die skakels hieronder om nutswenke te sien:
Plekhouerteks om 'n paar inlynskakels met nutswenke te demonstreer. Hierdie is nou net vuller, geen moordenaar nie. Inhoud wat hier geplaas word net om die teenwoordigheid van regte teks na te boots . En dit alles net om jou 'n idee te gee van hoe gereedskapwenke sal lyk wanneer dit in werklike situasies gebruik word. So hopelik het jy nou gesien hoe hierdie nutswenke oor skakels in die praktyk kan werk, sodra jy dit op jou eie webwerf of projek gebruik.
Beweeg oor die knoppies hieronder om die vier gereedskapwenke-rigtings te sien: bo, regs, onder en links. Aanwysings word weerspieël wanneer Bootstrap in RTL gebruik word.
<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="top" title="Tooltip on top">
Tooltip on top
</button>
<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="right" title="Tooltip on right">
Tooltip on right
</button>
<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Tooltip on bottom">
Tooltip on bottom
</button>
<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="left" title="Tooltip on left">
Tooltip on left
</button>
En met persoonlike HTML bygevoeg:
<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-html="true" title="<em>Tooltip</em> <u>with</u> <b>HTML</b>">
Tooltip with HTML
</button>
Met 'n SVG:
Sass
Veranderlikes
$tooltip-font-size: $font-size-sm;
$tooltip-max-width: 200px;
$tooltip-color: $white;
$tooltip-bg: $black;
$tooltip-border-radius: $border-radius;
$tooltip-opacity: .9;
$tooltip-padding-y: $spacer * .25;
$tooltip-padding-x: $spacer * .5;
$tooltip-margin: 0;
$tooltip-arrow-width: .8rem;
$tooltip-arrow-height: .4rem;
$tooltip-arrow-color: $tooltip-bg;
Gebruik
Die tooltip-inprop genereer inhoud en opmaak op aanvraag, en plaas by verstek gereedskapwenke na hul snellerelement.
Aktiveer die nutswenk via JavaScript:
var exampleEl = document.getElementById('example')
var tooltip = new bootstrap.Tooltip(exampleEl, options)
Oorloop auto
enscroll
Nutswenk-posisie poog om outomaties te verander wanneer 'n ouerhouer ons het overflow: auto
of overflow: scroll
hou van ons .table-responsive
, maar behou steeds die oorspronklike plasing se posisionering. Om dit op te los, stel die boundary
opsie (vir die flip-wysiger wat die popperConfig
opsie gebruik) op enige HTMLElement om die verstekwaarde, , te ignoreer 'clippingParents'
, soos document.body
:
var exampleEl = document.getElementById('example')
var tooltip = new bootstrap.Tooltip(exampleEl, {
boundary: document.body // or document.querySelector('#boundary')
})
Opmerk
Die vereiste opmaak vir 'n nutswenk is slegs 'n data
kenmerk en title
op die HTML-element wil jy 'n nutswenk hê. Die gegenereerde opmaak van 'n nutswenk is redelik eenvoudig, alhoewel dit 'n posisie vereis (by verstek gestel top
deur die inprop).
Maak gereedskapwenke werk vir sleutelbord- en hulptegnologiegebruikers
Jy moet slegs gereedskapwenke by HTML-elemente voeg wat tradisioneel sleutelbordfokusbaar en interaktief is (soos skakels of vormkontroles). Alhoewel arbitrêre HTML-elemente (soos <span>
s) fokusbaar gemaak kan word deur die tabindex="0"
kenmerk by te voeg, sal dit potensieel irriterende en verwarrende tabstops op nie-interaktiewe elemente vir sleutelbordgebruikers byvoeg, en die meeste ondersteunende tegnologieë kondig tans nie die nutswenk in hierdie situasie aan nie. Moet ook nie net daarop staatmaak hover
as die sneller vir jou nutswenk nie, want dit sal jou nutswenke onmoontlik maak om vir sleutelbordgebruikers te aktiveer.
<!-- HTML to write -->
<a href="#" data-bs-toggle="tooltip" title="Some tooltip text!">Hover over me</a>
<!-- Generated markup by the plugin -->
<div class="tooltip bs-tooltip-top" role="tooltip">
<div class="tooltip-arrow"></div>
<div class="tooltip-inner">
Some tooltip text!
</div>
</div>
Gedeaktiveerde elemente
Elemente met die disabled
kenmerk is nie interaktief nie, wat beteken dat gebruikers nie kan fokus, beweeg of daarop klik om 'n nutswenk (of popover) te aktiveer nie. As 'n oplossing, sal jy die nutswenk wil aktiveer vanaf 'n omhulsel <div>
of <span>
, ideaal gemaak sleutelbord-fokusbaar met tabindex="0"
.
<span class="d-inline-block" tabindex="0" data-bs-toggle="tooltip" title="Disabled tooltip">
<button class="btn btn-primary" type="button" disabled>Disabled button</button>
</span>
Opsies
Opsies kan deur data-kenmerke of JavaScript deurgegee word. Vir data-kenmerke, voeg die opsienaam by data-bs-
, soos in data-bs-animation=""
. Maak seker dat jy die kastipe van die opsienaam verander van camelCase na kebab-case wanneer die opsies deur data-kenmerke deurgegee word. Byvoorbeeld, in plaas van om te gebruik data-bs-customClass="beautifier"
, gebruik data-bs-custom-class="beautifier"
.
sanitize
Let daarop dat die ,
sanitizeFn
, en
allowList
opsies
om sekuriteitsredes
nie met behulp van data-kenmerke verskaf kan word nie.Naam | Tik | Verstek | Beskrywing |
---|---|---|---|
animation |
boolean | true |
Pas 'n CSS-vervaag-oorgang toe op die nutswenk |
container |
tou | element | onwaar | false |
Voeg die nutswenk by 'n spesifieke element. Voorbeeld: |
delay |
nommer | voorwerp | 0 |
Vertraag om die nutswenk (ms) te wys en te verberg - is nie van toepassing op handmatige snellertipe nie As 'n nommer verskaf word, word vertraging toegepas op beide versteek/wys Voorwerpstruktuur is: |
html |
boolean | false |
Laat HTML toe in die nutswenk. Indien waar, sal HTML-merkers in die nutswenk s'n Gebruik teks as jy bekommerd is oor XSS-aanvalle. |
placement |
tou | funksie | 'top' |
Hoe om die nutswenk te posisioneer - outomaties | top | onderste | links | reg. Wanneer 'n funksie gebruik word om die plasing te bepaal, word dit genoem met die tooltip DOM node as sy eerste argument en die sneller element DOM node as sy tweede. Die |
selector |
tou | onwaar | false |
As 'n kieser verskaf word, sal tooltip-objekte na die gespesifiseerde teikens gedelegeer word. In die praktyk word dit gebruik om ook gereedskapwenke toe te pas op dinamies bygevoegde DOM-elemente ( jQuery.on ondersteuning). Sien hierdie en 'n insiggewende voorbeeld . |
template |
string | '<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>' |
Baseer HTML om te gebruik wanneer die nutswenk geskep word. Die tooltip's
Die buitenste omhulselelement moet die |
title |
tou | element | funksie | '' |
Verstek titelwaarde as As 'n funksie gegee word, sal dit opgeroep word met sy |
trigger |
string | 'hover focus' |
Hoe tooltip geaktiveer word - klik | beweeg | fokus | handleiding. Jy kan verskeie snellers slaag; skei hulle met 'n spasie.
|
fallbackPlacements |
skikking | ['top', 'right', 'bottom', 'left'] |
Definieer terugvalplasings deur 'n lys van plasings in 'n skikking te verskaf (in volgorde van voorkeur). Vir meer inligting, verwys na Popper se gedragsdokumente |
boundary |
tou | element | 'clippingParents' |
Oorloopbeperkingsgrens van die nutswenk (is slegs van toepassing op Popper se preventOverflow-wysiger). By verstek is 'clippingParents' en kan dit 'n HTMLElement-verwysing aanvaar (slegs via JavaScript). Vir meer inligting, verwys na Popper se detectOverflow-dokumente . |
customClass |
tou | funksie | '' |
Voeg klasse by die nutswenk wanneer dit gewys word. Let daarop dat hierdie klasse bygevoeg sal word bykomend tot enige klasse wat in die sjabloon gespesifiseer word. Om veelvuldige klasse by te voeg, skei hulle met spasies: Jy kan ook 'n funksie deurgee wat 'n enkele string moet terugstuur wat bykomende klasname bevat. |
sanitize |
boolean | true |
Aktiveer of deaktiveer die ontsmetting. Indien geaktiveer 'template' en 'title' opsies sal ontsmet word. Sien die ontsmettingsmiddel-afdeling in ons JavaScript-dokumentasie . |
allowList |
voorwerp | Standaard waarde | Voorwerp wat toegelate eienskappe en etikette bevat |
sanitizeFn |
nul | funksie | null |
Hier kan jy jou eie ontsmettingsfunksie verskaf. Dit kan nuttig wees as jy verkies om 'n toegewyde biblioteek te gebruik om ontsmetting uit te voer. |
offset |
skikking | tou | funksie | [0, 0] |
Verskuiwing van die nutswenk relatief tot sy teiken. Jy kan 'n string in data-kenmerke met kommageskeide waardes deurgee soos: Wanneer 'n funksie gebruik word om die offset te bepaal, word dit opgeroep met 'n objek wat die drukkerplasing, die verwysing en drukkerrekse as sy eerste argument bevat. Die snellerelement DOM-nodus word as die tweede argument deurgegee. Die funksie moet 'n skikking met twee getalle terugstuur: . Vir meer inligting, verwys na Popper se offset-dokumente . |
popperConfig |
nul | voorwerp | funksie | null |
Sien Popper se konfigurasie om Bootstrap se verstek Popper-konfigurasie te verander . Wanneer 'n funksie gebruik word om die Popper-konfigurasie te skep, word dit genoem met 'n voorwerp wat die Bootstrap se verstek Popper-konfigurasie bevat. Dit help jou om die verstek met jou eie konfigurasie te gebruik en saam te voeg. Die funksie moet 'n konfigurasie-objek vir Popper terugstuur. |
Data-kenmerke vir individuele gereedskapwenke
Opsies vir individuele gereedskapwenke kan alternatiewelik gespesifiseer word deur die gebruik van data-kenmerke, soos hierbo verduidelik.
Die gebruik van funksie metpopperConfig
var tooltip = new bootstrap.Tooltip(element, {
popperConfig: function (defaultBsPopperConfig) {
// var newPopperConfig = {...}
// use defaultBsPopperConfig if needed...
// return newPopperConfig
}
})
Metodes
Asinchroniese metodes en oorgange
Alle API-metodes is asynchronies en begin 'n oorgang . Hulle keer terug na die oproeper sodra die oorgang begin is, maar voordat dit eindig . Daarbenewens sal 'n metode-oproep op 'n oorgangskomponent geïgnoreer word .
Wys
Onthul 'n element se nutswenk. Keer terug na die oproeper voordat die nutswenk werklik gewys is (dws voor die shown.bs.tooltip
gebeurtenis plaasvind). Dit word beskou as 'n "handmatige" sneller van die nutswenk. Gereedskapwenke met titels van geen lengte word nooit vertoon nie.
tooltip.show()
wegsteek
Versteek 'n element se nutswenk. Keer terug na die oproeper voordat die nutswenk eintlik versteek is (dws voor die hidden.bs.tooltip
gebeurtenis plaasvind). Dit word beskou as 'n "handmatige" sneller van die nutswenk.
tooltip.hide()
wissel
Wissel 'n element se nutswenk. Keer terug na die oproeper voordat die nutswenk werklik gewys of versteek is (dws voordat die shown.bs.tooltip
of hidden.bs.tooltip
gebeurtenis plaasvind). Dit word beskou as 'n "handmatige" sneller van die nutswenk.
tooltip.toggle()
wegdoen
Versteek en vernietig 'n element se nutswenk (Verwyder gestoorde data op die DOM-element). Gereedskapwenke wat delegering gebruik (wat met die selector
opsie geskep word ) kan nie individueel op afstammelinge-snellerelemente vernietig word nie.
tooltip.dispose()
aktiveer
Gee 'n element se nutswenk die vermoë om gewys te word. Gereedskapwenke is by verstek geaktiveer.
tooltip.enable()
deaktiveer
Verwyder die vermoë om 'n element se nutswenk te wys. Die nutswenk sal slegs gewys kan word as dit weer geaktiveer is.
tooltip.disable()
toggleAktiveer
Wissel die vermoë vir 'n element se nutswenk om gewys of versteek te word.
tooltip.toggleEnabled()
Opdateer
Dateer die posisie van 'n element se nutswenk op.
tooltip.update()
getInstance
Statiese metode wat jou toelaat om die tooltip-instansie te kry wat met 'n DOM-element geassosieer word
var exampleTriggerEl = document.getElementById('example')
var tooltip = bootstrap.Tooltip.getInstance(exampleTriggerEl) // Returns a Bootstrap tooltip instance
getOrCreateInstance
Statiese metode wat jou toelaat om die tooltip-instansie te kry wat met 'n DOM-element geassosieer word, of 'n nuwe een te skep ingeval dit nie geïnisialiseer is nie
var exampleTriggerEl = document.getElementById('example')
var tooltip = bootstrap.Tooltip.getOrCreateInstance(exampleTriggerEl) // Returns a Bootstrap tooltip instance
Gebeurtenisse
Soort gebeurtenis | Beskrywing |
---|---|
show.bs.tooltip |
Hierdie gebeurtenis begin onmiddellik wanneer die show instansiemetode geroep word. |
shown.bs.tooltip |
Hierdie gebeurtenis word afgevuur wanneer die nutswenk vir die gebruiker sigbaar gemaak is (sal wag vir CSS-oorgange om te voltooi). |
hide.bs.tooltip |
Hierdie gebeurtenis word onmiddellik afgevuur wanneer die hide instansiemetode geroep is. |
hidden.bs.tooltip |
Hierdie gebeurtenis word afgevuur wanneer die nutswenk klaar vir die gebruiker versteek is (sal wag vir CSS-oorgange om te voltooi). |
inserted.bs.tooltip |
Hierdie gebeurtenis word afgevuur na die show.bs.tooltip gebeurtenis wanneer die nutswenk-sjabloon by die DOM gevoeg is. |
var myTooltipEl = document.getElementById('myTooltip')
var tooltip = new bootstrap.Tooltip(myTooltipEl)
myTooltipEl.addEventListener('hidden.bs.tooltip', function () {
// do something...
})
tooltip.hide()