Я использую виртуальную прокрутку из cdk внутри sidenav, открывающего триггер на элементе mat-radio, это примерно код:
ts -
...
@Component({
selector: 'app-generic-options-list',
templateUrl: './generic-options-list.component.html',
styleUrls: ['./generic-options-list.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class GenericOptionsListComponent implements OnInit, OnChanges {
@Input() options: MultiSelectOption[];
_options: MultiSelectOption[];
...
ngOnInit(): void {
this.refreshOptions();
}
private refreshOptions() {
this._options = this.options;
...
}
template -
<cdk-virtual-scroll-viewport itemSize="30" class="scroll-viewport" *ngIf="type === 'single'">
<mat-radio-group >
<mat-radio-button
*ngFor="let option of selected"
[value]="option"
[checked]="true"
(click)="onRadioOptionClick(option)">
{{option.val}}
</mat-radio-button>
<mat-radio-button
*cdkVirtualFor="let option of _options"
[value]="option"
[checked]="false"
(click)="onRadioOptionClick(option)"
class="scroll-item"
>
{{option.val}}
</mat-radio-button>
</mat-radio-group>
</cdk-virtual-scroll-viewport>
и, конечно, правильный css.
и каждый раз, когда вышеуказанный компонент исчезает (очевидно, не уничтожается, так как не активирует метод onDestroy, когда это происходит) из родительского компонента дляизвестная причина (это должно), тогда я получаю эту ошибку, и sidenav застревает и не закрывается.(и всякие другие странные вещи), я где-то видел, что использование onPush решит эту проблему, но это не так.Как правильно это исправить?