Получение ошибки ExpressionChangedAfterItHasBeenCheckedError

Я работаю в приложении angular и получаю следующую ошибку:

ExpressionChangedAfterItHasBeenCheckedError: выражение изменилось после проверки. Предыдущее значение: 'ng-untouched: true'. Текущее значение: 'ng-untouched: false'.

У меня есть поле ввода, которое выглядит так:

<input matInput type = "text" [(ngModel)] = "description" #descriptionInput />
{{ descriptionInput.focus() }}

Мой компонент выглядит так:

@Component({
  selector: 'app-watermelon-dialog',
  templateUrl: './watermelon-dialog.component.html',
  styleUrls: ['./watermelon-dialog.component.scss']
})
export class WatermelonDialogComponent extends GeneralDialogComponent implements OnInit {

  public description : string;

  constructor(
    public dialogRef: MatDialogRef<GeneralDialogComponent>,
    @Inject(MAT_DIALOG_DATA) public dialogData: GeneralDialogModel,
    ngDynFormService: DynamicFormService,
    public generalDialogService: GeneralDialogService) {
      super(dialogRef,
        dialogData,
        ngDynFormService,
        generalDialogService);
  }

  ngOnInit() {
    this.description = this.dialogData.extra;
  }
}

Кто-нибудь знает, почему я получаю эту ошибку? И как мне от этого избавиться? Спасибо.

Из-за того, что что-то отображается так, как должно, интерполяция, которая у вас есть сразу после ввода, дает фокус полю ввода. Таким образом, при каждом обнаружении изменений вы будете уделять внимание этой области. Это не имеет смысла. Не делай этого. Удалите эту интерполяцию.

JB Nizet 29.11.2018 00:10

Удаление интерполяции действительно устранило проблему. Спасибо за это, JB. Но теперь я не могу сфокусировать поле ввода. Я создал здесь еще один вопрос: stackoverflow.com/questions/53544625/elementref-is-undefined

Gibran Shah 29.11.2018 18:38
Тестирование функциональных 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
0
2
189
0

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