美文网首页Angular
Angular5 错误: ngModel cannot be u

Angular5 错误: ngModel cannot be u

作者: 侯工 | 来源:发表于2019-08-10 14:50 被阅读3次

    在创建一个表单时,出现了这样的错误:


    原因是,在最外层的form中使用了 formGroup 指令,但在下面的某个input 元素中,使用了ngModel 指令,但没有加入formControl 指令或 formControlName 属性。

    也就是说,如果form中使用了formGroup,那么form中包含的所有input 元素都需要定义一个 formControl,如果不定义,就会报错。

    <form [formGroup]="form">
        <mat-form-field>
          <input matInput placeholder="IP(SNMP)" [formControl]="snmpIpCtrl" required>
          <mat-error *ngIf="snmpIpCtrl.hasError('required')">IP(SNMP)不能为空</mat-error>
          <mat-error *ngIf="snmpIpCtrl.hasError('pattern')">请输入有效的IP地址</mat-error>
        </mat-form-field>
        
        <div>
          <p>是否支持Netconf</p>
          <mat-radio-group [(ngModel)]="netconfFlag">
            <mat-radio-button value="0" color="primary">支持</mat-radio-button>
            <mat-radio-button value="1" color="primary">不支持</mat-radio-button>
          </mat-radio-group>
        </div>
    </form>
    
    解决方法1:

    在input元素中添加 formControl 指令或 formControlName 属性

    <div>
          <p>是否支持Netconf</p>
          <mat-radio-group [(ngModel)]="netconfFlag" [formControl]="netconfFlagCtrl">
            <mat-radio-button value="0" color="primary">支持</mat-radio-button>
            <mat-radio-button value="1" color="primary">不支持</mat-radio-button>
          </mat-radio-group>
    </div>
    

    并在相应的component.ts 中定义用于验证的FormControl。

    解决方法2:

    不添加formControl 指令或 formControlName 属性, 而添加 ngModelOptions 指令
    注意:ngModelOptions 必须和 ngModel 一起用!

    <div>
        <p>是否支持Netconf</p>
        <mat-radio-group [(ngModel)]="netconfFlag" [ngModelOptions]="{standalone: true}">
            <mat-radio-button value="0" color="primary">支持</mat-radio-button>
            <mat-radio-button value="1" color="primary">不支持</mat-radio-button>
        </mat-radio-group>
    </div>
    

    相关文章

      网友评论

        本文标题:Angular5 错误: ngModel cannot be u

        本文链接:https://www.haomeiwen.com/subject/bfjrjctx.html