Source

Toasts

Push Notifikatiounen un Är Besucher mat engem Toast, e liicht a liicht personaliséierbare Alarmmeldung.

Toasts si liicht Notifikatiounen entwéckelt fir d'Push Notifikatiounen ze mimikéieren, déi vu mobilen an Desktop Betribssystemer populariséiert goufen. Si gi mat Flexbox gebaut, sou datt se einfach ausriichten a positionéieren.

Iwwersiicht

Saachen ze wëssen wann Dir den Toast Plugin benotzt:

  • Wann Dir eis JavaScript aus der Quell baut, brauchutil.js et .
  • Toasts sinn opt-in aus Leeschtungsgrënn, also musst Dir se selwer initialiséieren .
  • Maacht weg datt Dir responsabel sidd fir Toasten ze positionéieren.
  • Toast verstoppt sech automatesch wann Dir net spezifizéiert autohide: false.

Beispiller

Basis

Ze encouragéieren extensible an prévisibel Toasts, Mir recommandéieren engem Header a Kierper. Toast Header benotzen display: flex, erlaabt eng einfach Ausrichtung vum Inhalt dank eise Margin a Flexbox Utilities.

Toasts si sou flexibel wéi Dir braucht an hu ganz wéineg erfuerderlech Markup. Op d'mannst verlaange mir en eenzegt Element fir Ären "getoasten" Inhalt ze enthalen an en Entlooss Knäppchen staark ze encouragéieren.

<div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
  <div class="toast-header">
    <img src="..." class="rounded mr-2" alt="...">
    <strong class="mr-auto">Bootstrap</strong>
    <small>11 mins ago</small>
    <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
  </div>
  <div class="toast-body">
    Hello, world! This is a toast message.
  </div>
</div>

Duerchsichteg

Toasts sinn och liicht transluzent, sou datt se vermëschen iwwer alles wat se erscheinen. Fir Browser déi d' backdrop-filterCSS Eegeschafte ënnerstëtzen, probéieren mir och d'Elementer ënner engem Toast ze verschwannen.

<div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
  <div class="toast-header">
    <img src="..." class="rounded mr-2" alt="...">
    <strong class="mr-auto">Bootstrap</strong>
    <small class="text-muted">11 mins ago</small>
    <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
  </div>
  <div class="toast-body">
    Hello, world! This is a toast message.
  </div>
</div>

Stacking

Wann Dir e puer Toasts hutt, gi mir Standard fir se vertikal op eng liesbar Manéier ze stackelen.

<div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
  <div class="toast-header">
    <img src="..." class="rounded mr-2" alt="...">
    <strong class="mr-auto">Bootstrap</strong>
    <small class="text-muted">just now</small>
    <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
  </div>
  <div class="toast-body">
    See? Just like this.
  </div>
</div>

<div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
  <div class="toast-header">
    <img src="..." class="rounded mr-2" alt="...">
    <strong class="mr-auto">Bootstrap</strong>
    <small class="text-muted">2 seconds ago</small>
    <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
  </div>
  <div class="toast-body">
    Heads up, toasts will stack automatically
  </div>
</div>

Placement

Plaz Toast mat personaliséierte CSS wéi Dir se braucht. Uewe riets gëtt dacks fir Notifikatiounen benotzt, sou wéi déi iewescht Mëtt. Wann Dir nëmmen een Toast gläichzäiteg wäert weisen, setzt d'Positionéierungsstiler direkt op der .toast.

Bootstrap Virun 11 Minutten
Moien Welt! Dëst ass en Toast Message.
<div aria-live="polite" aria-atomic="true" style="position: relative; min-height: 200px;">
  <div class="toast" style="position: absolute; top: 0; right: 0;">
    <div class="toast-header">
      <img src="..." class="rounded mr-2" alt="...">
      <strong class="mr-auto">Bootstrap</strong>
      <small>11 mins ago</small>
      <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
        <span aria-hidden="true">&times;</span>
      </button>
    </div>
    <div class="toast-body">
      Hello, world! This is a toast message.
    </div>
  </div>
</div>

Fir Systemer déi méi Notifikatiounen generéieren, betruecht e Wrapping-Element ze benotzen fir datt se einfach kënne stackelen.

<div aria-live="polite" aria-atomic="true" style="position: relative; min-height: 200px;">
  <!-- Position it -->
  <div style="position: absolute; top: 0; right: 0;">

    <!-- Then put toasts within -->
    <div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
      <div class="toast-header">
        <img src="..." class="rounded mr-2" alt="...">
        <strong class="mr-auto">Bootstrap</strong>
        <small class="text-muted">just now</small>
        <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="toast-body">
        See? Just like this.
      </div>
    </div>

    <div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
      <div class="toast-header">
        <img src="..." class="rounded mr-2" alt="...">
        <strong class="mr-auto">Bootstrap</strong>
        <small class="text-muted">2 seconds ago</small>
        <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="toast-body">
        Heads up, toasts will stack automatically
      </div>
    </div>
  </div>
</div>

Dir kënnt och lëschteg sinn mat Flexbox Utilities fir Toasts horizontal an / oder vertikal ze alignéieren.

<!-- Flexbox container for aligning the toasts -->
<div aria-live="polite" aria-atomic="true" class="d-flex justify-content-center align-items-center" style="min-height: 200px;">

  <!-- Then put toasts within -->
  <div class="toast" role="alert" aria-live="assertive" aria-atomic="true">
    <div class="toast-header">
      <img src="..." class="rounded mr-2" alt="...">
      <strong class="mr-auto">Bootstrap</strong>
      <small>11 mins ago</small>
      <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
        <span aria-hidden="true">&times;</span>
      </button>
    </div>
    <div class="toast-body">
      Hello, world! This is a toast message.
    </div>
  </div>
</div>

Accessibilitéit

Toasts si geduecht fir kleng Ënnerbriechungen fir Är Besucher oder Benotzer ze sinn, also fir déi mat Écran Lieser an ähnlechen Assistenztechnologien ze hëllefen, sollt Dir Är Toasts an enger aria-liveRegioun wéckelen . Ännerunge fir lieweg Regiounen (sou wéi d'Injektioun / d'Aktualiséierung vun engem Toastkomponent) ginn automatesch vun den Écran Lieser ugekënnegt ouni de Benotzer säi Fokus ze beweegen oder de Benotzer soss z'ënnerbriechen. Zousätzlech, abegraff aria-atomic="true"fir sécherzestellen datt de ganzen Toast ëmmer als eenzeg (atomar) Eenheet ugekënnegt gëtt, anstatt matzedeelen wat geännert gouf (wat zu Probleemer kéint féieren wann Dir nëmmen en Deel vum Inhalt vum Toast aktualiséiert, oder wann Dir deeselwechten Toast Inhalt op weist e spéideren Zäitpunkt). Wann déi néideg Informatioun wichteg ass fir de Prozess, zB fir eng Lëscht vu Feeler an enger Form, da benotzt d' Alarmkomponentamplaz Toast.

Bedenkt datt d'Live Regioun am Markup muss präsent sinn ier den Toast generéiert oder aktualiséiert gëtt. Wann Dir béid gläichzäiteg dynamesch generéiert an se op d'Säit sprëtzen, ginn se normalerweis net vun Hëllefstechnologien ugekënnegt.

Dir musst och den rolean aria-liveNiveau upassen ofhängeg vum Inhalt. Wann et e wichtege Message wéi e Feeler ass, benotzt role="alert" aria-live="assertive", soss benotzt role="status" aria-live="polite"Attributer.

Wéi den Inhalt deen Dir weist ännert, gitt sécher den delayTimeout ze aktualiséieren fir sécherzestellen datt d'Leit genuch Zäit hunn fir den Toast ze liesen.

<div class="toast" role="alert" aria-live="polite" aria-atomic="true" data-delay="10000">
  <div role="alert" aria-live="assertive" aria-atomic="true">...</div>
</div>

Wann Dir benotzt autohide: false, musst Dir en Zoumaache Knäppchen derbäi fir datt d'Benotzer den Toast entloossen.

<div role="alert" aria-live="assertive" aria-atomic="true" class="toast" data-autohide="false">
  <div class="toast-header">
    <img src="..." class="rounded mr-2" alt="...">
    <strong class="mr-auto">Bootstrap</strong>
    <small>11 mins ago</small>
    <button type="button" class="ml-2 mb-1 close" data-dismiss="toast" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
  </div>
  <div class="toast-body">
    Hello, world! This is a toast message.
  </div>
</div>

JavaScript Verhalen

Benotzung

Initialiséiere Toasts iwwer JavaScript:

$('.toast').toast(option)

Optiounen

Optiounen kënnen iwwer Datenattributer oder JavaScript weidergeleet ginn. Fir Datenattributer, fügen d'Optiounsnumm un data-, wéi an data-animation="".

Numm Typ Default Beschreiwung
Animatioun boolesch wouer Fëllt e CSS Fade Iwwergang op den Toast
autohide boolesch wouer Auto verstoppen den Toast
Retard Zuel 500 Verzögerung verstoppt den Toast (ms)

Methoden

Asynchron Methoden an Iwwergäng

All API Methoden sinn asynchron a starten en Iwwergang . Si ginn zréck op den Uruffer soubal den Iwwergang ugefaang ass, awer ier en eriwwer ass . Zousätzlech gëtt e Methodruff op eng Iwwergangskomponent ignoréiert .

Kuckt eis JavaScript Dokumentatioun fir méi Informatioun .

$().toast(options)

Befestegt engem Toast Handler zu engem Element Kollektioun.

.toast('show')

Entdeckt en Element Toast. Zréck op den Uruffer ier den Toast tatsächlech gewisen gouf (dh ier d' shown.bs.toastEvenement geschitt ass). Dir musst dës Method manuell ruffen, amplaz wäert Ären Toast net weisen.

$('#element').toast('show')

.toast('hide')

Verstoppt en Element Toast. Zréck op den Uruffer ier den Toast tatsächlech verstoppt ass (dh ier d' hidden.bs.toastEvenement geschitt ass). Dir musst dës Method manuell ruffen wann Dir gemaach autohidehutt false.

$('#element').toast('hide')

.toast('dispose')

Verstoppt en Element Toast. Ären Toast bleift op der DOM awer wäert net méi weisen.

$('#element').toast('dispose')

Evenementer

Event Typ Beschreiwung
show.bs.Toast Dëst Event brennt direkt wann d' showInstanzmethod genannt gëtt.
gewisen.bs.Toast Dëst Evenement gëtt gebrannt wann den Toast fir de Benotzer siichtbar gemaach gouf.
hide.bs.Toast Dëst Evenement gëtt direkt gebrannt wann d' hideInstanzmethod genannt gouf.
hidden.bs.Toast Dëst Evenement gëtt ofgeléist wann den Toast fäerdeg ass vum Benotzer verstoppt ze ginn.
$('#myToast').on('hidden.bs.toast', function () {
  // do something...
})