首页 > 解决方案 > 使用带有模板驱动表单的控件

问题描述

我正在尝试以角度使用 NGForm,但我不明白的是使用 ngForm 控件

谢谢

堆栈闪电战: https ://stackblitz.com/edit/angular-gt66nu

这是一个例子:

应用组件.html

<form name="form" #f="ngForm">

<div>
    <label>name</label>
    <input name="name" [(ngModel)]="model.name">
</div>
    <div>
        <label>surname</label>
        <input name="surname" [(ngModel)]="model.surname">  
    </div>


 </form>


应用组件.ts

import { Component, AfterViewInit,ViewChild } from '@angular/core';
import {NgForm} from '@angular/forms'

@Component({
selector: 'my-app',
templateUrl: 'app.component.html'
})

export class AppComponent implements AfterViewInit {
model: any = {};
oldForm;
@ViewChild('f', {static: false}) form: NgForm
onSubmit() {
 alert('SUCCESS!! :-)\n\n' + JSON.stringify(this.model))
}

ngAfterViewInit() {
     this.oldForm = this.form.controls
     console.log('form: ',this.form);
     this.form.form.valueChanges.subscribe( item => {
       console.log('item: ' ,item);
     })
   }
 }


控制台
在此处输入图像描述

标签: angularformscontrols

解决方案


查看Angular NgForm 文档或查看模板驱动表单的Angular 教程。

NgForm:指令

创建顶级 FormGroup 实例并将其绑定到表单以跟踪聚合表单值和验证状态。

简单的例子:

import {Component} from '@angular/core';
import {NgForm} from '@angular/forms';

@Component({
  selector: 'example-app',
  template: `
    <form #f="ngForm" (ngSubmit)="onSubmit(f)" novalidate>
      <input name="first" ngModel required #first="ngModel">
      <input name="last" ngModel>
      <button>Submit</button>
    </form>

    <p>First name value: {{ first.value }}</p>
    <p>First name valid: {{ first.valid }}</p>
    <p>Form value: {{ f.value | json }}</p>
    <p>Form valid: {{ f.valid }}</p>
  `,
})
export class SimpleFormComp {
  onSubmit(f: NgForm) {
    console.log(f.value);  // { first: '', last: '' }
    console.log(f.valid);  // false
  }
}

推荐阅读