2017-05-30 69 views
0

我有以下形式:角2 - ngForm.value沒有ngControl成員

import { Component } from '@angular/core' 

@Component({ 
    selector: 'form1', 
    template: ` 
     <div > 
     <form (ngSubmit)="onSubmit(f)" #f="ngForm"> 
      <input ngControl="email" type="text" id="mail" required>        
      <input ngControl="password" type="text" id="password" required> 
      <input ngControl="confirmPass" type="text" id="confirmPass" required>         
      <button type="submit">Submit </button> 
     </form> 
     </div>     ` 
}) 
export class Form1Component{ 
    onSubmit(form:any){ 
     console.log(form.value); 
    } 
} 

問題是form.value僅一個空的對象,並沒有ngControl指令的值的符號。我錯過了什麼嗎?

+0

你丟失了一些ngModel –

+0

的可能的複製[Angular2窗體:驗證,ngControl,ngModel等](https://stackoverflow.com/questions/35383765/angular2-forms-validations-ngcontrol-ngmodel-etc) – jonrsharpe

+0

這不是我的問題重複 – user2169286

回答

1

定義在形成name屬性是一個要求,從angular.io docs

在內部,角創建FormControl實例並用NgForm指令,角連接到<form>標籤登記它們。每個FormControl都是以您分配給name屬性的名稱註冊的。

因此,如果沒有名稱,它不會被視爲表單控件。我們還需要使用ngModel

NgForm指令爲表單元素添加了附加功能。它擁有你的元素與ngModel指令和name屬性

創建因此,所有的所有控件,您的模板應該是這樣的:

<form (ngSubmit)="onSubmit(f)" #f="ngForm"> 
    <input type="text" id="mail" name="email" ngModel required>        
    <input type="text" id="password" name="password" ngModel required> 
    <input type="text" id="confirmPass" name="confirmPass" ngModel required>         
    <button type="submit">Submit </button> 
</form> 
+0

您刪除了ngco​​ntrols。那麼ngcontrol的用途是什麼? – user2169286

+0

'ngControl'應該是舊的語法,在RC4版本之前,當哄騙Google搜索... :) https://www.barbarianmeetscoding.com/blog/2016/07/15/updating-your-angular-2-app-使用的最新形式-API-A-實用導向/ – Alex