Как bootstrap определяет проверенное состояние флажка / радиокнопки - PullRequest
1 голос
/ 21 февраля 2020

В настоящее время я пытаюсь отладить приложение, которое использует bootstrap HTML и CSS и преобразует его в другой формат документа. При использовании класса «custom-control-input» для стилизации флажков, флажки отображаются, но атрибут «флажок» теряется, и я получаю флажок bootstrap.

I Я уверен, что приложение проверяет, установлен ли атрибут, и нормальные флажки анализируются правильно.

Я знаю, что когда bootstrap используется для создания флажков следующим образом:

<div class="custom-control custom-checkbox">
<input type="checkbox" class="custom-control-input" id="defaultUnchecked">
<label class="custom-control-label" for="defaultUnchecked">Default unchecked</label>

bootstrap использует прозрачность, чтобы скрыть флажок, а затем использует 'пользовательская метка управления' для отображения флажка bootstrap.

То, что я не могу понять, это то, как bootstrap затем определяет, должен ли быть установлен флажок. Используются ли для этого только CSS правила, или задействован какой-то JavaScript / JQuery?

1 Ответ

1 голос
/ 21 февраля 2020

Я проверил, как bootstrap работает в этом случае, это делается с помощью псевдокласса :checked. Ссылка https://developer.mozilla.org/ru/docs/Web/CSS/: проверено .

Вот сравнительно весь код, который является реализацией bootstrap.

.custom-control {
    position: relative;
    display: block;
    min-height: 1.5rem;
    padding-left: 1.5rem;
}

.custom-control-input {
    position: absolute;
    left: 0;
    z-index: -1;
    width: 1rem;
    height: 1.25rem;
    opacity: 0;
}

.custom-control-label {
    position: relative;
    margin-bottom: 0;
    vertical-align: top;
}

label {
    display: inline-block;
    line-height: 1.5;
}

.custom-control-input:checked~.custom-control-label::before {
    color: #fff;
    border-color: #007bff;
    background-color: #007bff;
}
.custom-checkbox .custom-control-label::before {
    border-radius: .25rem;
}
.custom-control-label::before, .custom-file-label, .custom-select {
    transition: background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}
.custom-control-label::before {
    position: absolute;
    top: .25rem;
    left: -1.5rem;
    display: block;
    width: 1rem;
    height: 1rem;
    pointer-events: none;
    content: "";
    background-color: #fff;
    border: #adb5bd solid 1px;
}

.custom-checkbox .custom-control-input:checked~.custom-control-label::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26l2.974 2.99L8 2.193z'/%3e%3c/svg%3e");
}
.custom-control-label::after {
    position: absolute;
    top: .25rem;
    left: -1.5rem;
    display: block;
    width: 1rem;
    height: 1rem;
    content: "";
    background: no-repeat 50%/50% 50%;
}
*, ::after, ::before {
    box-sizing: border-box;
}
<div class="custom-control custom-checkbox">
  <input type="checkbox" class="custom-control-input" id="exampleCheck1">
  <label class="custom-control-label" for="exampleCheck1">Check me out</label>
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...