Невозможно установить цвет фона для непроверенного флажка - PullRequest
0 голосов
/ 10 ноября 2019

Я пытаюсь установить цвет фона не установленного флажка на белый, и я не могу найти способ сделать это. Он сохраняет синий цвет, когда он отмечен, а также когда не отмечен. Я пробовал с:

input[type=checkbox]:not(:checked) {
    background-color: white;
}

, а также:

input[type=checkbox]:after { (this one I don't think it's even valid)
    background-color: white;
}

Мой код на данный момент:

input[type=checkbox] {
  position: relative;
  cursor: pointer;
}

input[type=checkbox]:before {
  content: "";
  display: block;
  position: absolute;
  width: 16px;
  height: 16px;
  top: 0;
  left: 0;
  border: 1px solid #99AFC1;
  border-radius: 3px;
  background-color: #00AEEF;
  padding: 1px;
}

input[type=checkbox]:checked:after {
  content: "";
  display: block;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 2px;
  left: 6px;
}
<div class="container">
  <input type="checkbox" name="test">
</div>

Если у кого-то есть идеи, я буду признателен. Спасибо

Ответы [ 2 ]

2 голосов
/ 10 ноября 2019

Добавьте следующий стиль к вашему CSS:

input[type=checkbox]:checked::before {
  background-color: #00AEEF;
}

JsFiddle LINK

Надеюсь, это поможет.

2 голосов
/ 10 ноября 2019

Вот пример решения на основе вашего кода:

input[type=checkbox] {
  position: relative;
  cursor: pointer;
}

input[type=checkbox]:before {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  top: 0;
  left: 0;
  border: 1px solid #99AFC1;
  border-radius: 3px;
  padding: 1px;
  background-color: #FFFFFF;
}

input[type=checkbox]:checked:before {
  background-color: #00AEEF;
}

input[type=checkbox]:checked:after {
  content: "";
  display: block;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 2px;
  left: 6px;
}
<div class="container">
    <input type="checkbox" name="test">
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...