Прогрессбар
Документация и примеры использования настраиваемых индикаторов выполнения Bootstrap с поддержкой составных полос, анимированных фонов и текстовых меток.
Как это устроено
Компоненты Progress состоят из двух HTML-элементов, CSS для установки ширины и нескольких атрибутов. Мы не используем элемент HTML5 <progress>, гарантируя, что Вы можете складывать индикаторы выполнения, анимировать их, и поместите на них текстовые метки.
- Мы используем
.progressв качестве оболочки, чтобы указать максимальное значение индикатора выполнения. - Оболочке
.progressтакже требуются атрибутыrole="progress"иaria, чтобы сделать ее доступной, включая доступное имя (используяaria-label,aria-labelledbyили подобное). - Мы используем внутренний
.progress-barисключительно для визуальной панели и метки. .progress-barтребует встроенного стиля, служебного класса или пользовательского CSS для установки его ширины.- Мы предоставляем специальный класс
.progress-stackedдля создания нескольких индикаторов выполнения.
Сложите все это вместе, и вы получите следующие примеры.
<divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="0"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 0%"></div></div><divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 25%"></div></div><divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="50"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 50%"></div></div><divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 75%"></div></div><divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="100"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 100%"></div></div>Размер бара
Ширина
Bootstrap предоставляет несколько утилит для установки ширины. В зависимости от ваших потребностей, это может помочь быстро настроить ширину .progress-bar.
<divclass="progress"role="progressbar"aria-label="Basic example"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar w-75"></div></div>Высота
Вы только устанавливаете значение height в контейнере .progress, поэтому, если вы измените это значение, внутренний .progress-bar автоматически изменит размер соответственно.
<divclass="progress"role="progressbar"aria-label="Example 1px high"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"style="height: 1px"><divclass="progress-bar"style="width: 25%"></div></div><divclass="progress"role="progressbar"aria-label="Example 20px high"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"style="height: 20px"><divclass="progress-bar"style="width: 25%"></div></div>Метки
Добавляйте метки к индикаторам выполнения, помещая текст в .progress-bar.
<divclass="progress"role="progressbar"aria-label="Example with label"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar"style="width: 25%">25%</div></div>Обратите внимание, что по умолчанию содержимое внутри .progress-bar контролируется overflow: hidden, поэтому оно не выходит за пределы полосы. Если ваш индикатор выполнения короче, чем его метка, содержимое будет ограничено и может стать нечитаемым. Чтобы изменить это поведение, вы можете использовать .overflow-visible из утилит переполнения, но не забудьте также определить явный цвет текста , чтобы текст оставался читабельным. Однако имейте в виду, что в настоящее время этот подход не учитывает цветовые режимы.
<divclass="progress"role="progressbar"aria-label="Example with label"aria-valuenow="10"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar overflow-visible text-dark"style="width: 10%">Длинный текст метки для индикатора выполнения, установленный на темный цвет</div></div>Фон
Используйте фоновые служебные классы, чтобы изменить внешний вид отдельных индикаторов выполнения.
<divclass="progress"role="progressbar"aria-label="Success example"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-success"style="width: 25%"></div></div><divclass="progress"role="progressbar"aria-label="Info example"aria-valuenow="50"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-info"style="width: 50%"></div></div><divclass="progress"role="progressbar"aria-label="Пример предупреждения"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-warning"style="width: 75%"></div></div><divclass="progress"role="progressbar"aria-label="Пример опасности"aria-valuenow="100"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-danger"style="width: 100%"></div></div>.visually-hidden.
Если вы добавляете метки к индикаторам выполнения с настраиваемым цветом фона, не забудьте также установить соответствующий цвет текста, чтобы метки оставались читаемыми и иметь достаточную контрастность.
<divclass="progress"role="progressbar"aria-label="Пример успеха"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-success"style="width: 25%">25%</div></div><divclass="progress"role="progressbar"aria-label="Пример информации"aria-valuenow="50"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-info text-dark"style="width: 50%">50%</div></div><divclass="progress"role="progressbar"aria-label="Пример предупреждения"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-warning text-dark"style="width: 75%">75%</div></div><divclass="progress"role="progressbar"aria-label="Пример опасности"aria-valuenow="100"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar bg-danger"style="width: 100%">100%</div></div>Кроме того, вы можете использовать новые комбинированные вспомогательные классы цвет и фон.
<divclass="progress"role="progressbar"aria-label="Пример предупреждения"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar text-bg-warning"style="width: 75%">75%</div></div>Множественные полосы
Вы можете включить несколько компонентов прогресса в контейнер с .progress-stacked, чтобы создать один сложенный индикатор выполнения. Обратите внимание, что в этом случае стиль для установки визуальной ширины индикатора выполнения должен применяться к элементам .progress, а не .progress-bar.
<divclass="progress-stacked"><divclass="progress"role="progressbar"aria-label="Segment one"aria-valuenow="15"aria-valuemin="0"aria-valuemax="100"style="width: 15%"><divclass="progress-bar"></div></div><divclass="progress"role="progressbar"aria-label="Segment two"aria-valuenow="30"aria-valuemin="0"aria-valuemax="100"style="width: 30%"><divclass="progress-bar bg-success"></div></div><divclass="progress"role="progressbar"aria-label="Segment three"aria-valuenow="20"aria-valuemin="0"aria-valuemax="100"style="width: 20%"><divclass="progress-bar bg-info"></div></div></div>Полосатые
Добавьте .progress-bar-striped к любому .progress-bar, чтобы применить полосу через градиент CSS к цвету фона индикатора выполнения.
<divclass="progress"role="progressbar"aria-label="Default striped example"aria-valuenow="10"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped"style="width: 10%"></div></div><divclass="progress"role="progressbar"aria-label="Success striped example"aria-valuenow="25"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped bg-success"style="width: 25%"></div></div><divclass="progress"role="progressbar"aria-label="Info striped example"aria-valuenow="50"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped bg-info"style="width: 50%"></div></div><divclass="progress"role="progressbar"aria-label="Warning striped example"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped bg-warning"style="width: 75%"></div></div><divclass="progress"role="progressbar"aria-label="Danger striped example"aria-valuenow="100"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped bg-danger"style="width: 100%"></div></div>Анимированные полосы
Полосатый градиент также можно анимировать. Добавьте .progress-bar-animated в .progress-bar, чтобы анимировать полосы справа налево с помощью анимации CSS3.
<divclass="progress"role="progressbar"aria-label="Animated striped example"aria-valuenow="75"aria-valuemin="0"aria-valuemax="100"><divclass="progress-bar progress-bar-striped progress-bar-animated"style="width: 75%"></div></div>CSS
Переменные
Добавлено в версии 5.2.0Как часть развивающегося подхода Bootstrap к переменным CSS, индикаторы выполнения теперь используют локальные переменные CSS в .progress для расширенной настройки в реальном времени. Значения переменных CSS задаются через Sass, поэтому настройка Sass по-прежнему поддерживается.
--#{$prefix}progress-height:#{$progress-height};@include rfs($progress-font-size,--#{$prefix}progress-font-size);--#{$prefix}progress-bg:#{$progress-bg};--#{$prefix}progress-border-radius:#{$progress-border-radius};--#{$prefix}progress-box-shadow:#{$progress-box-shadow};--#{$prefix}progress-bar-color:#{$progress-bar-color};--#{$prefix}progress-bar-bg:#{$progress-bar-bg};--#{$prefix}progress-bar-transition:#{$progress-bar-transition};Переменные Sass
$progress-height:1rem;$progress-font-size:$font-size-base*.75;$progress-bg:var(--#{$prefix}secondary-bg);$progress-border-radius:var(--#{$prefix}border-radius);$progress-box-shadow:var(--#{$prefix}box-shadow-inset);$progress-bar-color:$white;$progress-bar-bg:$primary;$progress-bar-animation-timing:1slinearinfinite;$progress-bar-transition:width.6sease;Ключевые кадры
Используется для создания CSS-анимации для .progress-bar-animated. Включен в scss/_progress-bar.scss.
@if$enable-transitions{@keyframesprogress-bar-stripes{0%{background-position-x:$progress-height;}}}