У меня есть Реактивные формы на моем сайте, который использует FormBuilder.
У меня есть два поля, которые имеют FormControl
s и массив полей, созданных пользователем, который является FormArray
.
Когда я отправлял данные на сервер, оказалось, что FormArray
отправляет вместо массива строку с перечисленными элементами с запятой.
Как я могу отправить данные на сервер, используя массив?
Это мои методы класса
formGroup = this.fb.group({
link: [null, [
Validators.required,
Validators.pattern(/^(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~:/?#[\]@!\$&'\(\)\*\+,;=.]+$/)
]],
image: [null, Validators.required],
features: this.fb.array([this.fb.control('', Validators.required)])
});
beforeSubmit(): FormData {
const formData = new FormData();
formData.append('link', this.link.value);
formData.append('image', this.image.value);
formData.append('features', this.features.value);
return formData;
}
submit() {
console.log('submit');
const formData = this.beforeSubmit() as FormData;
this.ss.postSite(formData).subscribe(
response => {
console.log(response);
}
);
}
и обслуживание
postSite(input: FormData) {
console.log('posting');
return this.http.post<Site>(this.API_URL, input, this.HEADERS).pipe(
catchError(this.handleError)
);
}