1. ホーム
  2. javascript

[解決済み] ngModel' は 'input' の既知のプロパティではないため、バインドできません。

2022-03-16 10:23:31

質問

Angularアプリを起動すると、コンポーネントが表示されていなくても、以下のエラーが発生します。

をコメントアウトする必要があります。 <input> を使用することで、私のアプリが動作するようになります。

zone.js:461 Unhandled Promise rejection: Template parse errors:
Can't bind to 'ngModel' since it isn't a known property of 'input'. ("
   <div>
      <label>Created:</label>
      <input  type="text" [ERROR ->][(ngModel)]="test" placeholder="foo" />
   </div>
</div>"): InterventionDetails@4:28 ; Zone: <root> ; Task: Promise.then ; Value: 

Hero plunkerを見ているのですが、私のコードと違いがわかりません。

以下はコンポーネントファイルです。

import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';
import { Intervention } from '../../model/intervention';

@Component({
   selector: 'intervention-details',
   templateUrl: 'app/intervention/details/intervention.details.html',
   styleUrls: ['app/intervention/details/intervention.details.css']
})

export class InterventionDetails
{
   @Input() intervention: Intervention;

   public test : string = "toto";
}

解決方法は?

はい、それです。で、その app.module.ts ファイルを追加しただけです。

import { FormsModule } from '@angular/forms';

[...]

@NgModule({
  imports: [
    [...]
    FormsModule
  ],
  [...]
})