Angular 5 не может прочитать свойство 'remove' из неопределенного - PullRequest
0 голосов
/ 08 июня 2018

Итак, я работал над ASP.NET Core 2 и Angular 5 (я парень из Django / Rails Vue), и после нескольких простых примеров я решил создать один из моих старых продуктов сновый стек.Дело в том, что у меня возникают проблемы с выяснением источника этой ошибки.

Вот мой шаблон компонента входа в систему:

<div class="login-container">
  <h2 class="login-title">{{title}}</h2>
  <form [formGroup]="form" (ngSubmit)="onSubmit()" class="form-horizontal">
    <div class="form-group" *ngClass="{' has-errors has-feedback' : hasErrors('Username')}">
      <input type="text" formControlName="Username" class="form-control" required placeholder="Usuario o Email" />
    </div>
    <div class="form-group" *ngClass="{' has-errors has-feedback' : hasErrors('Password')}">
      <input type="password" formControlName="Password" class="form-control" required placeholder="*****" />
    </div>
    <button type="submit" [disabled]="form.invalid" class="btn btn-md btn-success">Entrar</button>
  </form>
</div>

и вот Typescript:

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css']
})
export class LoginComponent implements OnInit {


  title: string;
  form: FormGroup;

  constructor(private router: Router,
    private fb: FormBuilder,
    private authService: AuthService,
    @Inject('BASE_URL') private baseUrl: string) {
    this.title = 'Entrar';
  }

  ngOnInit(): void {
    this.createForm();
  }

  createForm() {
    this.form = this.fb.group({
      Username: ['', Validators.required],
      Password: ['', Validators.required]
    });
    console.log(this.form);
  }
  onBack() {
    this.router.navigate(['home']);
  }
  getFormControl(name: string) {
    return this.form.get(name);
  }
  isValid(name: string) {
    const e = this.getFormControl(name);
    return e && e.valid;
  }
  isChanged(name: string) {
    const e = this.getFormControl(name);
    return e && (e.dirty || e.touched);
  }

  hasErrors(name) {
    return this.isChanged(name) && !this.isValid(name);
  }

  onSubmit() {
    const url = this.baseUrl + 'api/token/auth';
    const username = this.form.value.Username;
    const password = this.form.value.Password;
    this.authService.login(username, password)
      .subscribe(res => this.router.navigate(['home']),
        err => this.form.setErrors({ 'auth': 'Usuario o password incorrecto' }));
  }
}

Я читал аналогичные вопросы в SO, но в конце концов решил опубликовать это, потому что:

  1. Насколько я могу сказать, в моем шаблоне ничего нет undefined (я думаю, что единственная привязка здесь - это form)
  2. Я не звоню / не читаю ничего с именем remove.

Заранее спасибо.

Ответы [ 2 ]

0 голосов
/ 05 декабря 2018

Я получил ту же ошибку при случайном добавлении [ngClass] к <ng-container />

0 голосов
/ 08 июня 2018

Нашел ответ после прохождения кода шаблона:

Вместо *ngClass это должно было быть [ngClass], поскольку * является сокращением для структурных директив.Запись * ngClass делает некоторые неправильные вызовы DOM, и именно поэтому я закончил с ошибкой.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...