从ngFor中动态创建的多个滑动滑块获取值

问题描述 投票:0回答:1

我正在Angular中动态创建多个垫滑块,如下所示:

<ng-container *ngFor="let parameter of parameterValues; let i = index;">
  <mat-slider (input)="onInputChange($event)" min="1" max="{{ parameter.length }}" step="1" value="1" id="{{ 'myslider' + i }}"></mat-slider>
</ng-container>

当任何一个滑块位置改变时,我想触发一个事件,该事件随后调用另一个函数,该函数接收一个数组'sliderValues',其中包含每个动态创建的mat-slider值。我正在尝试使用:

  onInputChange(event: MatSliderChange) {
   for (let i = 0; i < this.results.parameterNames.length; i++) {
    const theid = "myslider" + i;
    var ele = document.getElementById(theid)
    console.log((ele as HTMLInputElement).id + " is the id");
    console.log((ele as HTMLInputElement).value + " is the value");
    this.sliderValues.push((ele as HTMLInputElement).value);
   }
   //some function called here which accepts 'this.sliderValues' as a parameter 
  }

目前不起作用;我无法访问滑块的值。在控制台中,我看到正确报告了'id',但'value'是'undefined'。任何帮助表示赞赏,如果需要,我愿意以完全不同的方式进行。

angular typescript slider ngfor mat-slider
1个回答
0
投票

我找到了一种更清洁的方法。该值可以从以下位置获得:

event.value

和ID:

event.source._elementRef.nativeElement.id

值和源都可以从MatSliderChange事件对象中访问

© www.soinside.com 2019 - 2024. All rights reserved.