@laravel_creative_3103

Как сделать так, чтоб модальное окно срабатывала только для одного «Универа»?

Условно, есть модальное окно, которое я бы хотел открыть, при нажатии на то, что в красной линии:
646e897323128882828300.png

Но, когда нажимаешь на одну из них, открывается сразу все модалки:
646e89d21b4bc372064972.png

...

В коде html таким образом прописал:
<p>unversity-components works!</p>
<div *ngFor="let univer of universities">
  <div>{{ univer.nameOfUniversity }}</div>
  <button (click)="modal = true">
    смотреть подробную информацию о студентах
  </button>
  <button (click)="removeUniver(univer.id!)">
    Удалить универ {{ univer.nameOfUniversity }}
  </button>

  <div *ngIf="modal">
    <button (click)="modal = false">Закрыть модальное окно</button>
    <h1>Ученики {{ univer.nameOfUniversity }}</h1>

    <div *ngFor="let student of univer.students">
      <div>{{ student.firstName }}</div>
      <div>{{ student.lastName }}</div>
    </div>
  </div>
</div>

<input type="text" [(ngModel)]="nameOfUniversity" placeholder="Универ" />
<button (click)="addUniver()">Добавить новый универ</button>


В TS таким образом написал:
export class UnversityComponentsComponent implements OnInit {
  universities: IUniversity[] = [];
  nameOfUniversity: string = '';
  modal: boolean = false;

  constructor(private unverService: UniverService) {}
  ngOnInit(): void {
    this.getAll();
  }

  getAll() {
    this.unverService.getAll().subscribe((univers) => {
      this.universities = univers;
      console.log(this.universities);
    });
  }

  addUniver() {
    const newUniver: IUniversity = {
      nameOfUniversity: this.nameOfUniversity,
    };
    this.unverService.addUniver(newUniver).subscribe((newUniver) => {
      this.universities.unshift(newUniver);
      this.nameOfUniversity = '';
      console.log(newUniver);
    });
  }

  removeUniver(id: number) {
    this.unverService.removeUniver(id).subscribe(() => {
      this.universities = this.universities.filter((u) => u.id !== id);
    });
  }
}


Как в ангуляре правильно написать, чтоб открывалась только та модалка, которую я бы хотел открыть?
  • Вопрос задан
  • 69 просмотров
Пригласить эксперта
Ответы на вопрос 1
delphinpro
@delphinpro Куратор тега JavaScript
frontend developer
Университеты вы перебираете в цикле, а переменная modal у вас одна общая на всех. Сделайте отдельную переменную для каждого универа.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
28 мар. 2024, в 18:16
1000 руб./за проект
28 мар. 2024, в 18:15
90000 руб./за проект
28 мар. 2024, в 18:05
5000 руб./за проект