Показать / скрыть дочерние компоненты

Представьте себе следующий фрагмент HTML-кода, который является шаблоном компонента Angular:

<form [formGroup] = "myForm">
  <app-one></app-one>
  <app-two [someService] = "someService"></app-two>
  <app-three></app-three>
  <button type = "button"  (click) = "submit()">Submit</button>
  <button type = "button"  (click) = "next()">Next</button>
</form>

Я хочу не показывать все дочерние компоненты сразу (пользовательский интерфейс станет слишком большим), а по одному при нажатии кнопки Next. Во-первых, Я хочу, чтобы появился <app-one>, затем после Next<app-two> для замены <app-one> и после второго Next щелкните <app-three> для замены <app-two> и Кнопка Submit для замены кнопки Next. Я могу реализовать это, используя директивы *ngIf, однако я уверен, что должен быть лучший способ сделать это (используя ng-template, ng-container?). Любая помощь?

Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Angular и React для вашего проекта веб-разработки?
Angular и React для вашего проекта веб-разработки?
Когда дело доходит до веб-разработки, выбор правильного front-end фреймворка имеет решающее значение. Angular и React - два самых популярных...
Эпизод 23/17: Twitter Space о будущем Angular, Tiny Conf
Эпизод 23/17: Twitter Space о будущем Angular, Tiny Conf
Мы провели Twitter Space, обсудив несколько проблем, связанных с последними дополнениями в Angular. Также прошла Angular Tiny Conf с 25 докладами.
Угловой продивер
Угловой продивер
Оригинал этой статьи на турецком языке. ChatGPT используется только для перевода на английский язык.
Мое недавнее углубление в Angular
Мое недавнее углубление в Angular
Недавно я провел некоторое время, изучая фреймворк Angular, и я хотел поделиться своим опытом со всеми вами. Как человек, который любит глубоко...
Освоение Observables и Subjects в Rxjs:
Освоение Observables и Subjects в Rxjs:
Давайте начнем с основ и постепенно перейдем к более продвинутым концепциям в RxJS в Angular
1
0
113
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Я думаю, что то, что вы представляете, похоже на степпер, этот ссылка на сайт покажет вам пример.

Вы также можете создать переменную, чтобы сохранить шаг, на котором находится пользователь. Например:

<form [formGroup] = "myForm">
   <app-one *ngIf = "step==1"></app-one>
   <app-two *ngIf = "step==2" [someService] = "someService"></app-two>
   <app-three *ngIf = "step==3"></app-three>
   <button type = "button"  (click) = "submit()">Submit</button>
   <button type = "button"  (click) = "next()">Next</button>
</form>

Правильный. * ngIf без надобности увеличит цикломатическую сложность. Используйте * ngSwitchCase.

<form [formGroup] = "myForm" [ngSwitch] = "currentStep">
  <app-one *ngSwitchCase = "step-1"></app-one>
  <app-two *ngSwitchCase = "step-2" [someService] = "someService"></app-two>
  <app-three *ngSwitchCase = "step-3"></app-three>
  <button type = "button"  (click) = "submit()">Submit</button>
  <button type = "button"  (click) = "next()">Next</button>
</form>

Значение currentStep можно обновить из следующего метода

public next(): void {
// Default value of selectedStep being 1
currentStep = `step-${++this.selectedStep}`;
}

Другие вопросы по теме