Төп эчтәлеккә күчү Документлар навигациясенә күчү
in English

Сигнализация

Кулланучының типик гамәлләре өчен контекстуаль кире элемтә хәбәрләрен бирегез.

Мисаллар

Сигнализация теләсә нинди озынлыктагы текст өчен, шулай ук ​​өстәмә ябу төймәсе өчен бар. Дөрес стилизацияләү өчен кирәкле сигез контекст классның берсен кулланыгыз (мәсәлән, .alert-success). Эштән чыгару өчен, JavaScript плагинын кулланыгыз .

<div class="alert alert-primary" role="alert">
  A simple primary alert—check it out!
</div>
<div class="alert alert-secondary" role="alert">
  A simple secondary alert—check it out!
</div>
<div class="alert alert-success" role="alert">
  A simple success alert—check it out!
</div>
<div class="alert alert-danger" role="alert">
  A simple danger alert—check it out!
</div>
<div class="alert alert-warning" role="alert">
  A simple warning alert—check it out!
</div>
<div class="alert alert-info" role="alert">
  A simple info alert—check it out!
</div>
<div class="alert alert-light" role="alert">
  A simple light alert—check it out!
</div>
<div class="alert alert-dark" role="alert">
  A simple dark alert—check it out!
</div>
Ярдәмче технологияләргә мәгънә җиткерү

Мәгънә өстәү өчен төс куллану визуаль күрсәткеч кенә бирә, ул ярдәмче технологияләр кулланучыларга җиткерелмәячәк - экран укучылары кебек. Төс белән күрсәтелгән мәгълүматның эчтәлектән ачык булуын (мәсәлән, күренгән текст), яки .visually-hiddenкласс белән яшерелгән өстәмә текст кебек альтернатив чаралар аша кертелүен тәэмин итегез.

Тере мисал

Сигнализацияне күрсәтү өчен астагы төймәгә басыгыз (башлау өчен эчке стильләр белән яшерелгән), аннары урнаштырылган ябык төймә белән аны кире кагарга (һәм юкка чыгарырга).

<div id="liveAlertPlaceholder"></div>
<button type="button" class="btn btn-primary" id="liveAlertBtn">Show live alert</button>

Тере уяу демоны башлау өчен без түбәндәге JavaScript кулланабыз:

var alertPlaceholder = document.getElementById('liveAlertPlaceholder')
var alertTrigger = document.getElementById('liveAlertBtn')

function alert(message, type) {
  var wrapper = document.createElement('div')
  wrapper.innerHTML = '<div class="alert alert-' + type + ' alert-dismissible" role="alert">' + message + '<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button></div>'

  alertPlaceholder.append(wrapper)
}

if (alertTrigger) {
  alertTrigger.addEventListener('click', function () {
    alert('Nice, you triggered this alert message!', 'success')
  })
}

.alert-linkТеләсә нинди уяулык эчендә төсле сылтамаларны тиз тәэмин итү өчен , файдалы класс кулланыгыз .

<div class="alert alert-primary" role="alert">
  A simple primary alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-secondary" role="alert">
  A simple secondary alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-success" role="alert">
  A simple success alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-danger" role="alert">
  A simple danger alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-warning" role="alert">
  A simple warning alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-info" role="alert">
  A simple info alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-light" role="alert">
  A simple light alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>
<div class="alert alert-dark" role="alert">
  A simple dark alert with <a href="#" class="alert-link">an example link</a>. Give it a click if you like.
</div>

Өстәмә эчтәлек

Сигнализация шулай ук ​​рубрикалар, абзацлар һәм бүлүчеләр кебек өстәмә HTML элементларын үз эченә ала.

<div class="alert alert-success" role="alert">
  <h4 class="alert-heading">Well done!</h4>
  <p>Aww yeah, you successfully read this important alert message. This example text is going to run a bit longer so that you can see how spacing within an alert works with this kind of content.</p>
  <hr>
  <p class="mb-0">Whenever you need to, be sure to use margin utilities to keep things nice and tidy.</p>
</div>

Икона

Шулай ук, иконалар белән хәбәрләр ясау өчен, сез флексбок программаларын һәм Bootstrap иконаларын куллана аласыз. Сезнең иконаларга һәм эчтәлеккә карап, сез күбрәк коммуналь хезмәтләр яки махсус стильләр өстәргә теләрсез.

<div class="alert alert-primary d-flex align-items-center" role="alert">
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="currentColor" class="bi bi-exclamation-triangle-fill flex-shrink-0 me-2" viewBox="0 0 16 16" role="img" aria-label="Warning:">
    <path d="M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z"/>
  </svg>
  <div>
    An example alert with an icon
  </div>
</div>

Сезнең хәбәрләр өчен бердән артык иконка кирәкме? Ботстрап иконаларын күбрәк кулланырга һәм бер үк иконаларны кат-кат сылтау өчен җирле SVG спритын ясарга уйлагыз.

<svg xmlns="http://www.w3.org/2000/svg" style="display: none;">
  <symbol id="check-circle-fill" fill="currentColor" viewBox="0 0 16 16">
    <path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z"/>
  </symbol>
  <symbol id="info-fill" fill="currentColor" viewBox="0 0 16 16">
    <path d="M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z"/>
  </symbol>
  <symbol id="exclamation-triangle-fill" fill="currentColor" viewBox="0 0 16 16">
    <path d="M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z"/>
  </symbol>
</svg>

<div class="alert alert-primary d-flex align-items-center" role="alert">
  <svg class="bi flex-shrink-0 me-2" width="24" height="24" role="img" aria-label="Info:"><use xlink:href="#info-fill"/></svg>
  <div>
    An example alert with an icon
  </div>
</div>
<div class="alert alert-success d-flex align-items-center" role="alert">
  <svg class="bi flex-shrink-0 me-2" width="24" height="24" role="img" aria-label="Success:"><use xlink:href="#check-circle-fill"/></svg>
  <div>
    An example success alert with an icon
  </div>
</div>
<div class="alert alert-warning d-flex align-items-center" role="alert">
  <svg class="bi flex-shrink-0 me-2" width="24" height="24" role="img" aria-label="Warning:"><use xlink:href="#exclamation-triangle-fill"/></svg>
  <div>
    An example warning alert with an icon
  </div>
</div>
<div class="alert alert-danger d-flex align-items-center" role="alert">
  <svg class="bi flex-shrink-0 me-2" width="24" height="24" role="img" aria-label="Danger:"><use xlink:href="#exclamation-triangle-fill"/></svg>
  <div>
    An example danger alert with an icon
  </div>
</div>

Эштән чыгару

JavaScript плагинын кулланып, теләсә нинди хәбәрне кире кагарга мөмкин. Менә ничек:

  • Сигнализация плагинын яки тупланган Bootstrap JavaScript йөкләгәнегезгә инаныгыз.
  • Якын төймәгә һәм класска өстәгез .alert-dismissible, алар уяулыкның уң ягына өстәмә ябыштыралар һәм ябык төймә урнаштыралар.
  • Ябу төймәсенә data-bs-dismiss="alert"JavaScript функциясен эшләтеп җибәрүче атрибутны өстәгез. <button>Барлык җайланмаларда дөрес тәртип өчен элементны кулланыгыз .
  • Аларны җибәргәндә хәбәрләрне җанландыру өчен, .fadeклассларны .showөстәргә онытмагыз.

Сез моны турыдан-туры демо белән күрә аласыз:

<div class="alert alert-warning alert-dismissible fade show" role="alert">
  <strong>Holy guacamole!</strong> You should check in on some of those fields below.
  <button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
</div>
Сигнализация бетерелгәч, элемент бит структурасыннан тулысынча бетерелә. Әгәр дә клавиатура кулланучы ябык төймә ярдәмендә кисәтүне кире кага икән, аларның игътибары кинәт юкка чыгачак һәм, браузерга карап, бит / документ башына кире кайтачак. Шуңа күрә, без closed.bs.alertвакыйганы тыңлаган һәм программаль focus()рәвештә битнең иң урынлы урынына куелган өстәмә JavaScript кертергә тәкъдим итәбез. Әгәр дә сез фокусны интерактив булмаган элементка күчерергә уйлыйсыз икән, гадәттә фокус кабул итми tabindex="-1", элементка өстәргә онытмагыз.

Сасс

Variзгәрешләр

$alert-padding-y:               $spacer;
$alert-padding-x:               $spacer;
$alert-margin-bottom:           1rem;
$alert-border-radius:           $border-radius;
$alert-link-font-weight:        $font-weight-bold;
$alert-border-width:            $border-width;
$alert-bg-scale:                -80%;
$alert-border-scale:            -70%;
$alert-color-scale:             40%;
$alert-dismissible-padding-r:   $alert-padding-x * 3; // 3x covers width of x plus default padding on either side

Вариант миксин

$theme-colorsБезнең хәбәрләр өчен контекстуаль үзгәртүче класслар булдыру өчен кулланыла .

@mixin alert-variant($background, $border, $color) {
  color: $color;
  @include gradient-bg($background);
  border-color: $border;

  .alert-link {
    color: shade-color($color, 20%);
  }
}

Loop

Миксин белән үзгәртүче класслар тудыручы цикл alert-variant().

// Generate contextual modifier classes for colorizing the alert.

@each $state, $value in $theme-colors {
  $alert-background: shift-color($value, $alert-bg-scale);
  $alert-border: shift-color($value, $alert-border-scale);
  $alert-color: shift-color($value, $alert-color-scale);
  @if (contrast-ratio($alert-background, $alert-color) < $min-contrast-ratio) {
    $alert-color: mix($value, color-contrast($alert-background), abs($alert-color-scale));
  }
  .alert-#{$state} {
    @include alert-variant($alert-background, $alert-border, $alert-color);
  }
}

JavaScript тәртибе

Башлау

Элементларны хәбәр итү

var alertList = document.querySelectorAll('.alert')
var alerts =  [].slice.call(alertList).map(function (element) {
  return new bootstrap.Alert(element)
})

Сигнализацияне кире кагу өчен, компонентны JS API аша кул белән башларга кирәк түгел. Куллану белән data-bs-dismiss="alert", компонент автоматик рәвештә башланачак һәм дөрес эштән чыгарылачак.

Төгәлрәк мәгълүмат өчен триггерлар бүлеген карагыз .

Триггерлар

Эштән азат ителергә мөмкин, аста күрсәтелгәнчә , уяуdata төймәдәге атрибут белән :

<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>

яисә аста күрсәтелгәнчә кулланып, сигнализация читендәге төймәдә:data-bs-target

<button type="button" class="btn-close" data-bs-dismiss="alert" data-bs-target="#my-alert" aria-label="Close"></button>

Игътибар итегез, кисәтүне ябу аны DOMдан бетерәчәк.

Методлар

Метод Тасвирлау
close DOM-тан алып, кисәтүне япа. Әгәр дә .fadeэлементта .showкласслар булса, кисәтү бетерелгәнче юкка чыгачак.
dispose Элементның уяулыгын юкка чыгара. (DOM элементында сакланган мәгълүматны бетерә)
getInstance DOM элементына бәйләнгән уяу инстанцияне алырга мөмкинлек бирүче статик ысул, сез аны болай куллана аласыз:bootstrap.Alert.getInstance(alert)
getOrCreateInstance Статик ысул, ул DOM элементына бәйләнгән уяу инстанцияне кире кайтара яки башланмаган очракта яңасын булдыра. Сез аны болай куллана аласыз:bootstrap.Alert.getOrCreateInstance(element)
var alertNode = document.querySelector('.alert')
var alert = bootstrap.Alert.getInstance(alertNode)
alert.close()

Вакыйгалар

Bootstrap-ның уяу плагины уяу функциягә керү өчен берничә вакыйганы фаш итә.

Вакыйга Тасвирлау
close.bs.alert closeМисал ысулы чакырылганда шунда ук янып тора .
closed.bs.alert Сигнализация ябылганда һәм CSS күчү тәмамлангач.
var myAlert = document.getElementById('myAlert')
myAlert.addEventListener('closed.bs.alert', function () {
  // do something, for instance, explicitly move focus to the most appropriate element,
  // so it doesn't get lost/reset to the start of the page
  // document.getElementById('...').focus()
})