Improve this Doc View Source form.FormController
- type in module ng
FormController keeps track of all its controls and nested forms as well as the state of them, such as being valid/invalid or dirty/pristine.
Each form directive creates an instance of FormController.
Methods
-
$rollbackViewValue();
Rollback all form controls pending updates to the
$modelValue.Updates may be pending by a debounced event or because the input is waiting for a some future event defined in
ng-model-options. This method is typically needed by the reset button of a form that usesng-model-optionsto pend updates. -
$commitViewValue();
Commit all form controls pending updates to the
$modelValue.Updates may be pending by a debounced event or because the input is waiting for a some future event defined in
ng-model-options. This method is rarely needed asNgModelControllerusually handles calling this in response to input events. -
$addControl(control);
Register a control with the form. Input elements using ngModelController do this automatically when they are linked.
Note that the current state of the control will not be reflected on the new parent form. This is not an issue with normal use, as freshly compiled and linked controls are in a
$pristinestate.However, if the method is used programmatically, for example by adding dynamically created controls, or controls that have been previously removed without destroying their corresponding DOM element, it's the developers responsibility to make sure the current state propagates to the parent form.
For example, if an input control is added that is already
$dirtyand has$errorproperties, calling$setDirty()and$validate()afterwards will propagate the state to the parent form.Parameters
Param Type Details control objectcontrol object, either a
form.FormControlleror anngModel.NgModelController -
$removeControl(control);
Deregister a control from the form.
Input elements using ngModelController do this automatically when they are destroyed.
Note that only the removed control's validation state (
$errorsetc.) will be removed from the form.$dirty,$submittedstates will not be changed, because the expected behavior can be different from case to case. For example, removing the only$dirtycontrol from a form may or may not mean that the form is still$dirty.Parameters
Param Type Details control objectcontrol object, either a
form.FormControlleror anngModel.NgModelController -
$setValidity();
Sets the validity of a form control.
This method will also propagate to parent forms.
-
$setDirty();
Sets the form to a dirty state.
This method can be called to add the 'ng-dirty' class and set the form to a dirty state (ng-dirty class). This method will also propagate to parent forms.
-
$setPristine();
Sets the form to its pristine state.
This method sets the form's
$pristinestate to true, the$dirtystate to false, removes theng-dirtyclass and adds theng-pristineclass. Additionally, it sets the$submittedstate to false.This method will also propagate to all the controls contained in this form.
Setting a form back to a pristine state is often useful when we want to 'reuse' a form after saving or resetting it.
-
$setUntouched();
Sets the form to its untouched state.
This method can be called to remove the 'ng-touched' class and set the form controls to their untouched state (ng-untouched class).
Setting a form controls back to their untouched state is often useful when setting the form back to its pristine state.
-
$setSubmitted();
Sets the form to its submitted state.
Properties
-
$pristine
booleanTrue if user has not interacted with the form yet.
-
$dirty
booleanTrue if user has already interacted with the form.
-
$valid
booleanTrue if all of the containing forms and controls are valid.
-
$invalid
booleanTrue if at least one containing control or form is invalid.
-
$pending
booleanTrue if at least one containing control or form is pending.
-
$submitted
booleanTrue if user has submitted the form even if its invalid.
-
$error
ObjectIs an object hash, containing references to controls or forms with failing validators, where:
- keys are validation tokens (error names),
-
values are arrays of controls or forms that have a failing validator for given error name.
Built-in validation tokens:
-
email maxmaxlengthminminlengthnumberpatternrequiredurldatedatetimelocaltimeweekmonth
© 2010–2017 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://code.angularjs.org/1.5.11/docs/api/ng/type/form.FormController