Тосты
Push-уведомления для ваших посетителей с тостом, легким и легко настраиваемым предупреждающим сообщением.
Тосты — это облегченные уведомления, имитирующие push-уведомления, популярные в мобильных и настольных операционных системах. Они созданы с помощью flexbox, поэтому их легко выравнивать и позиционировать.
Обзор
Что нужно знать при использовании плагина toast:
- Если вы создаете наш JavaScript из исходного кода, для этого требуется
util.js
. - Всплывающие уведомления добавляются из соображений производительности, поэтому вы должны инициализировать их самостоятельно .
- Обратите внимание, что вы несете ответственность за размещение тостов.
- Тосты будут автоматически скрываться, если вы не укажете
autohide: false
.
Примеры
Базовый
Чтобы поощрять расширяемые и предсказуемые всплывающие уведомления, мы рекомендуем заголовок и тело. Заголовки тостов используют display: flex
, что позволяет легко выравнивать контент благодаря нашим утилитам margin и flexbox.
Тосты настолько гибки, насколько вам нужно, и требуют минимальной разметки. Как минимум, мы требуем, чтобы один элемент содержал ваш «поджаренный» контент, и настоятельно рекомендуем использовать кнопку «Отклонить».
полупрозрачный
Тосты также слегка полупрозрачны, поэтому они сливаются с тем, на чем могут появиться. Для браузеров, поддерживающих backdrop-filter
свойство CSS, мы также попытаемся размыть элементы всплывающего уведомления.
Укладка
Когда у вас есть несколько тостов, мы по умолчанию размещаем их вертикально друг над другом в удобочитаемом виде.
Размещение
Размещайте всплывающие уведомления с пользовательским CSS по мере необходимости. Верхний правый часто используется для уведомлений, как и верхний средний. Если вы собираетесь показывать только одно всплывающее уведомление за раз, поместите стили позиционирования прямо в файл .toast
.
Для систем, которые генерируют больше уведомлений, рассмотрите возможность использования элемента-обертки, чтобы их можно было легко складывать.
Вы также можете воспользоваться утилитами flexbox для выравнивания тостов по горизонтали и/или по вертикали.
Доступность
Тосты предназначены для того, чтобы отвлекать ваших посетителей или пользователей, поэтому, чтобы помочь тем, у кого есть программы чтения с экрана и аналогичные вспомогательные технологии, вы должны обернуть свои всплывающие уведомления в aria-live
область . Изменения в активных регионах (такие как внедрение/обновление компонента всплывающего уведомления) автоматически объявляются программами чтения с экрана без необходимости перемещать фокус пользователя или иным образом прерывать его. Кроме того, включите, aria-atomic="true"
чтобы гарантировать, что все всплывающее уведомление всегда объявляется как единая (атомарная) единица, а не объявляет, что было изменено (что может привести к проблемам, если вы обновляете только часть содержимого всплывающего уведомления или отображаете одно и то же содержимое всплывающего уведомления в более поздний момент времени). Если необходимая информация важна для процесса, например, для списка ошибок в форме, используйте компонент предупреждения .вместо тостов.
Обратите внимание, что активная область должна присутствовать в разметке до создания или обновления всплывающего уведомления. Если вы динамически генерируете оба одновременно и вставляете их на страницу, они, как правило, не будут объявлены вспомогательными технологиями.
Вам также необходимо адаптировать уровень role
и aria-live
в зависимости от контента. Если это важное сообщение, например ошибка, используйте role="alert" aria-live="assertive"
, в противном случае используйте role="status" aria-live="polite"
атрибуты.
По мере изменения содержимого, которое вы показываете, обязательно обновите время delay
ожидания , чтобы у людей было достаточно времени, чтобы прочитать тост.
При использовании autohide: false
необходимо добавить кнопку закрытия, чтобы пользователи могли закрыть всплывающее уведомление.
Поведение JavaScript
Применение
Инициализируйте тосты через JavaScript:
Опции
Параметры можно передавать через атрибуты данных или JavaScript. Для атрибутов данных добавьте имя опции к data-
, как в data-animation=""
.
Имя | Тип | По умолчанию | Описание |
---|---|---|---|
анимация | логический | истинный | Примените к всплывающему уведомлению плавный переход CSS |
авто-скрытие | логический | истинный | Автоматически скрывать тост |
задерживать | количество | 500 |
Задержка скрытия всплывающего уведомления (мс) |
Методы
Асинхронные методы и переходы
Все методы API являются асинхронными и запускают переход . Они возвращаются к вызывающей стороне сразу после начала перехода, но до его завершения . Кроме того, вызов метода переходного компонента будет игнорироваться .
Дополнительную информацию см. в нашей документации по JavaScript .
$().toast(options)
Присоединяет обработчик всплывающих уведомлений к коллекции элементов.
.toast('show')
Показывает тост элемента. Возвращает вызывающему абоненту до фактического отображения всплывающего уведомления (т. е. до того , как shown.bs.toast
произойдет событие). Вы должны вручную вызвать этот метод, вместо этого ваш тост не будет отображаться.
.toast('hide')
Скрывает тост элемента. Возвращает вызывающему объекту до того, как всплывающее уведомление будет фактически скрыто (т. е. до того , как hidden.bs.toast
произойдет событие). Вы должны вручную вызвать этот метод, если вы autohide
сделали false
.
.toast('dispose')
Скрывает тост элемента. Ваше всплывающее уведомление останется в DOM, но больше не будет отображаться.
События
Тип события | Описание |
---|---|
показать.bs.toast | Это событие срабатывает сразу же при show вызове метода экземпляра. |
показанный.bs.toast | Это событие запускается, когда всплывающее уведомление становится видимым для пользователя. |
скрыть.bs.toast | Это событие запускается сразу после hide вызова метода экземпляра. |
скрытый.bs.toast | Это событие запускается, когда всплывающее уведомление перестает быть скрытым от пользователя. |