We’ve covered reactive and template-driven forms in the past. One of the nice features of reactive forms is the FormArray
class. You can use FormArray
for a form where the number of inputs is dynamic and can increase or decrease:
data:image/s3,"s3://crabby-images/f6d7d/f6d7de53afa035c85c6949601d1d0c662d254d27" alt=""
To achieve the above, we create a FormArray
in our component and add a method so we can append new FormControls
to that array:
data:image/s3,"s3://crabby-images/ef558/ef558a117d0393ecb527bb33ad545a2acfa2662c" alt=""
Then, we use a @for
block to display all controls of that array in our template, including a button to add new names to the list. Note that we store the index of each control in a local variable i
:
data:image/s3,"s3://crabby-images/315fa/315fadf9a5676ad3e602a9ce06862bf6f6dd23ff" alt=""
We can even add support for the removal of form elements using the removeAt
method of FormArray
and the index of the element to remove:
data:image/s3,"s3://crabby-images/a06ed/a06ed4ebfb648f8edabeb5bce70cc788de50657d" alt=""
And that’s it! We can check that the FormArray
value is updated correctly with the following expression:
data:image/s3,"s3://crabby-images/e2a68/e2a687bf7953b6876da8f81b3bf1caf0a14af8b4" alt=""
You can see that code in action on Stackblitz here. You can read this excellent guest post from Jennifer Wadella on my blog for more information on dynamic forms.