Стили начальной загрузки применяются ко всему, кроме переключателей - PullRequest
1 голос
/ 04 июня 2019

Я практикую обработку форм с помощью Angular, и мне нравится использовать bootstrap, чтобы все выглядело красиво.По какой-то причине стили начальной загрузки применяются к остальной части формы, но отображаются только переключатели со стилем HTML по умолчанию.

Снимок экрана представления браузера

Я уже пытался возиться с тем, куда я помещаю имя класса, изменяя способ обертывания входных данных, но ничего не работает.Я должен отметить, что я следую учебному пособию онлайн, и мой код точно соответствует инструктору.Тем не менее, он появляется с красивым бутстрапом, синим и белым, а мой остается HTML серым и черным.Я хочу исправить это так, чтобы он отображался синим и белым, пожалуйста, воздержитесь от ответов, в которых говорится, что он "должен быть" серым и черным.

HTML

      <form (ngSubmit)="onSubmit()" #f="ngForm">
        <div
          id="user-data"
          ngModelGroup="userData"
        #userData="ngModelGroup">
          <div class="form-group">
            <label for="username">Username</label>
            <input
              type="text"
              id="username"
              class="form-control"
              ngModel
              name="username"
            required>
          </div>
          <div class="form-group">
            <label for="email">Mail</label>
            <input
              type="email"
              id="email"
              class="form-control"
              ngModel
              name="email"
              required
              #email = "ngModel"
            >
          </div>
        </div>
        <div class="radio" *ngFor="let gender of genders">
          <label>
            <input
              class="radio"
              type="radio"
              name="gender"
              ngModel
              [value]="gender">
            {{gender}}
          </label>
        </div>
        <button
          class="btn btn-primary"
          type="submit"
          [disabled]="!f.valid"
        >Submit</button>
      </form>

TypeScript

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  @ViewChild('f') signupForm: NgForm;
  defaultValue = 'teacher';
  answer = '';
  genders = ['male', 'female'];
}

1 Ответ

1 голос
/ 04 июня 2019

Вам необходимо создать собственную кнопку-переключатель

Подробнее

Пример скопированный сверху ссылка

/* The container */
.container {
  display: block;
  position: relative;
  padding-left: 35px;
  margin-bottom: 12px;
  cursor: pointer;
  font-size: 22px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Hide the browser's default radio button */
.container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

/* Create a custom radio button */
.checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: #eee;
  border-radius: 50%;
}

/* On mouse-over, add a grey background color */
.container:hover input ~ .checkmark {
  background-color: #ccc;
}

/* When the radio button is checked, add a blue background */
.container input:checked ~ .checkmark {
  background-color: #2196F3;
}

/* Create the indicator (the dot/circle - hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the indicator (dot/circle) when checked */
.container input:checked ~ .checkmark:after {
  display: block;
}

/* Style the indicator (dot/circle) */
.container .checkmark:after {
 	top: 9px;
	left: 9px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: white;
}
<!DOCTYPE html>
<html>

<body>

<h1>Custom Radio Buttons</h1>
<label class="container">One
  <input type="radio" checked="checked" name="radio">
  <span class="checkmark"></span>
</label>
<label class="container">Two
  <input type="radio" name="radio">
  <span class="checkmark"></span>
</label>
<label class="container">Three
  <input type="radio" name="radio">
  <span class="checkmark"></span>
</label>
<label class="container">Four
  <input type="radio" name="radio">
  <span class="checkmark"></span>
</label>

</body>
</html>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...