In my Ionic 5 app I have to display my custom component horizontally by ion-slides and repet each slider vertically in loop.
Following in the code.
<ng-container *ngFor="let item of mainList; let i = index;">
  <ion-slides pager="true" loop="true" [options]="slideOpts" (ionSlideDidChange)="slideChanged(i)" #slides>
      <ion-slide *ngFor="let id of item.subList; let j = index;">
        <app-cust-comp [input]="j"></app-cust-comp>
      </ion-slide>
  </ion-slides>
</ng-container>
Following method for getting the active slide number
      @ViewChild('slides') slides: IonSlides;
      async slideChanged(i: number){
        const activeSlideNumber = await this.slides.getActiveIndex();
        console.log(i+' '+slideNumber);
      }
My goal is get the correct active slide number for each index. The sliders are working perfectly and the value of activeSlideNumber is correct every time for only the first (index 0) slider. For all sliders except first one the value of activeSlideNumber is always the last value change by first (index 0) slider. So if I slide the first (index 0) slider 3 times and the activeSlideNumber for index 0 is 2. It will always come as 2 for all other slider.
 
                        
The issue is that you have multiple instances of an
ion-sliderin your view butViewChildis used to get only one instance of the slider.You should use
ViewChildreninstead:@ViewChildren(IonSlides) slides: QueryList<IonSlides>;Please take a look at this Stackblitz demo.
Component:
View: