Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34

Как отправить динамическую форму в axios

28.03.2023, 18:24. Показов 1215. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!!!
Есть динамическая форма:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
<h1>Add Stage</h1>
            <form className={classes.root} onSubmit={handleSubmit}>
                {inputFields.map((inputField, index) => (
                    <div key={index}>
                        <TextField
                            placeholder="Enter name job"
                            name="name_work"
                            label="Name Job"
                            value={inputField.name_work}
                            onChange={event => handleChangeInput(index, event)}
                        />
                        <TextField
                            name="release_dates"
                            label="Release Dates"
                            value={inputField.release_dates}
                            onChange={event => handleChangeInput(index, event)}
                        />
                        <TextField
                            name="due_dates"
                            label="Due Dates"
                            value={inputField.due_dates}
                            onChange={event => handleChangeInput(index, event)}         
                        />                            
                        <IconButton
                            onClick={()=> handleRemoveFields(index)}
                        >
                            <RemoveIcon />
                        </IconButton>
                        <IconButton
                            onClick={() => handleAddFields()}
                        >
                            <AddIcon />
                        </IconButton>
                    </div>
                ))}
                <Button 
                    className={classes.button}
                    variant="contained" 
                    color="primary" 
                    type="submit" 
                    endIcon={<Icon>send</Icon>} 
                    // onClick={AddWorksInfo}
                    onClick={handleSubmit}
                >
                        Add Stage
                </Button>
            </form>
Хочу отправить данные на api rest. Как поступить в случае обычной(нединамической) формы - вопросов нет(код ниже):
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 const handleSubmit = async(e) => {
        
        let formField = new FormData()
 
        formField.append('name_work', inputFields.name_work)
        formField.append('release_dates', inputFields.release_dates)
        formField.append('due_dates', inputFields.due_dates)
 
        await axios({
            method: 'post',
            url: 'http://localgost:8000/work/',
            data: formField
        }).then((response) => {
            console.log(response.data);
            navigate('/Works', {replace: true});
        })
    };
Да, я действительно не могу отправить данные динамической формы. Может надо было сделать так (да, это не работает, однако идея может такая):
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 let formField = new FormData()
       {inputFields.map((inputField, index) => (
 
            formField.append('name_work', inputFields.name_work),
            formField.append('release_dates', inputFields.release_dates),
            formField.append('due_dates', inputFields.due_dates)
 
        ))}
 
 
        await axios({
            method: 'post',
            url: 'http://localgost:8000/work/',
            data: formField
        }).then((response) => {
            console.log(response.data);
            navigate('/Works', {replace: true});
        })
Не знаю как присвоить каждой группе этого динамического массива уникальные ключи, ведь проблема в следующем - "Each child in a list should have a unique "key" prop."

Помогите пожалуйста)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.03.2023, 18:24
Ответы с готовыми решениями:

Не могу отправить axios post запрос
Всем доброе время суток. Сижу и пытаюсь отправить данные на сервер в виде: { &quot;title&quot;: &quot;&quot;, ...

Как обработать динамическую форму?
Есть форма, в которой поля (text, radio, checkbox, textarea) создаются при помощи jquery. Нажали на кнопку &quot;добавить&quot; -...

Как обработать динамическую форму?
Данные пользователей(id, name) подгружаются из базы данных. Динамически строится список, в котором выводится имя юзера и рядом кнопка...

11
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
28.03.2023, 21:31  [ТС]
Добрый день!
Подскажите как отправить данные из динамической формы на api rest.
А если конкретно, не работает код, приведенный ниже:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
const handleSubmit = async(e) => {
        e.preventDefault();
        console.log("InputFields", inputFields);
       
        await axios({
            method: 'post',
            url: 'http://localhost:8000/work/',
            data: inputFields
        }).then((response) => {
            console.log(response.data);
            navigate('/Works', {replace: true});
        })
    };
Где метод handleSubmit вызывается при нажатии кнопки формы "Отправить".
inputFields имеет следующий вид:
JavaScript
1
2
3
const [inputFields, setInputFields] = useState([
        { name_work: '', release_dates: '', due_dates: '' },
    ]);
-Это структура динамической формы.
Ниже приведен код динамической формы:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<h1>Add Stage</h1>
            <form className={classes.root} onSubmit={handleSubmit}>
                {inputFields.map((inputField, index) => (
                    <div key={index}>
                        <TextField
                            placeholder="Enter name job"
                            name="name_work"
                            label="Name Job"
                            value={inputField.name_work}
                            onChange={event => handleChangeInput(index, event)}
                        />
                        <TextField
                            name="release_dates"
                            label="Release Dates"
                            value={inputField.release_dates}
                            onChange={event => handleChangeInput(index, event)}
                        />
                        <TextField
                            name="due_dates"
                            label="Due Dates"
                            value={inputField.due_dates}
                            onChange={event => handleChangeInput(index, event)}         
                        />                            
                    </div>
                ))}
                <Button 
                    className={classes.button}
                    variant="contained" 
                    color="primary" 
                    type="submit" 
                    endIcon={<Icon>send</Icon>} 
                    // onClick={AddWorksInfo}
                    onClick={handleSubmit}
                >
                        Add Stage
                </Button>
            </form>
В консоле на странице при отправки выводится InputFields (прикрепила фото).

Я пробовала делать перебором массива, код ниже:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
inputFields.forEach(function(entry) {
                formField.append('id', entry.id);
                formField.append('name_work', entry.name_work);
                formField.append('release_dates', entry.release_dates);
                formField.append('due_dates', entry.due_dates);
        });
 
        await axios({
            method: 'post',
            url: 'http://localhost:8000/work/',
            data: inputFields
        }).then((response) => {
            console.log(response.data);
            navigate('/Works', {replace: true});
        })
-Однако при таком способе, который я привела выше - в бд записываются данные только последней формы из их динамического количества.

Подскажите пожалуйста, не знаю я уже что сделать
Миниатюры
Как отправить динамическую форму в axios  
0
Модератор
 Аватар для vxg
3407 / 2178 / 354
Регистрация: 13.01.2012
Сообщений: 8,448
29.03.2023, 08:56
I am i, что делает handleChangeInput ? кажется он должен вызывать setInputFields. в этом случае handleSubmit отработает как надо
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
31.03.2023, 15:55  [ТС]
Именно так у меня все и есть. Вот handleChangeInput:
JavaScript
1
2
3
4
5
6
const handleChangeInput = (index, event) => {
        // console.log(index, event.target.name)
        const values = [...inputFields];
        values[index][event.target.name] = event.target.value;
        setInputFields(values);
    }
Однако handleSubmit не работает как надо.
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
31.03.2023, 16:10  [ТС]
Вот в методе axios в data записываю values (
JavaScript
1
const values = [...inputFields];
)
JavaScript
1
2
3
4
5
6
7
8
await axios({
            method: 'post',
            url: 'http://localhost:8000/work/',
            data: values
        }).then((response) => {
            console.log(response.data);
            navigate('/Works', {replace: true});
        })
Однако вот что я вижу в консоли (прикрепила рисунок)
Миниатюры
Как отправить динамическую форму в axios  
0
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
31.03.2023, 16:16
А так?
JavaScript
1
data: {payload: inputFields}
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
31.03.2023, 16:35  [ТС]
К сожалению, опять ошибка (рисунок).
Миниатюры
Как отправить динамическую форму в axios  
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
31.03.2023, 17:47  [ТС]
Может стоит в цикле перебрать, что-то вроде этого:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
const handleSubmit = async(e) => {
        e.preventDefault();
        console.log("InputFields", inputFields);
 
        let formField = new FormData()
 
        var array = [];
 
        inputFields.forEach(function(entry) {
                formField.append('id', entry.id);
                formField.append('name_work', entry.name_work);
                formField.append('release_dates', entry.release_dates);
                formField.append('due_dates', entry.due_dates);
        });
 
        await axios({
            method: 'post',
            url: 'http://localhost:8000/work/',
            // data: formField
            // data: {payload: inputFields}
            data: values
        }).then((response) => {
            console.log(response.data);
            navigate('/works', {replace: true});
        })
Но при таком раскладе запоминаются только последние данные. Так что наверно не подходит такой вариант
0
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
31.03.2023, 18:20
я выше советовал просто пальцем в небо, трудно понять в чем проблема

Хорошо что с формой у Вас отправляется

я эксперементировал с тестовыми данными

мой тестовый сервер для приема формы
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
const express = require("express");
var bodyParser = require("body-parser");
var cors = require("cors");
const app = express();
const port = 4000;
const multer = require("multer");
app.use(
  cors({
    origin: "*",
  })
);
 
app.post("/form", multer().none(), (req, res) => {
  console.log("Body");
  console.dir(req.body, { depth: null });
});
 
app.listen(port, () => {
  console.log(`Example app listening on port ${port}`);
});
на клиенте

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    let formField = new FormData()
    let inputFields = []
    for (let i = 0; i < 10; i++) {
        formField.append('id[]', i);
        formField.append('name_work[]', "work"+i);
        formField.append('release_dates[]', new Date());
    }
    axios({
        method: 'post',
        url: 'http://localhost:4000/form/',
        data: formField
    }).then((response) => {
        console.log(response.data);
    }).catch(function(error) {
        console.log('Error', error.message);
    })
данные на сервере

JavaScript
1
2
3
4
5
6
7
8
9
{
  id: [ '0', '1', '2' ],
  name_work: [ 'work0', 'work1', 'work2' ],
  release_dates: [
    'Fri Mar 31 2023 18:14:12 GMT+0300 (Moscow Standard Time)',
    'Fri Mar 31 2023 18:14:12 GMT+0300 (Moscow Standard Time)',
    'Fri Mar 31 2023 18:14:12 GMT+0300 (Moscow Standard Time)'
  ]
}

еще можно так отправить данные через форму на клиенте

JavaScript
1
2
3
    for (let i = 0; i < 3; i++) {
        formField.append(i, JSON.stringify({id: i, name_work: "work" + i, 'release_dates': new Date()}));
    }
на сервере получим
JavaScript
1
2
3
4
5
{
  '0': '{"id":0,"name_work":"work0","release_dates":"2023-03-31T15:14:12.534Z"}',
  '1': '{"id":1,"name_work":"work1","release_dates":"2023-03-31T15:14:12.534Z"}',
  '2': '{"id":2,"name_work":"work2","release_dates":"2023-03-31T15:14:12.534Z"}',
}
мой сервер получает все днные, скорее всего у вас проблема либо с настройкой сервера или обработкой принятых данных либо с отправкой

еще можно в испекторе браузера на вкладке network посмотреть что реально отправилось смотри прикрепленный файл

================
На счет ошибки 400
нужно понять что вызывает http 400, тут есть несколько советов

прежде всего добавьте блок перехвата ошибок catch

JavaScript
1
2
3
4
5
6
7
8
9
10
11
    axios({
        method: 'post',
        url: 'http://localhost:4000/json1/',
        data: [{ id: { data: [new Date("Thu, 28 Apr 2016 22:02:17 GMT")] } }, { id: "232323" }]
 
 
    }).then((response) => {
        console.log(response.data);
    }).catch(function(error) {
        console.log('Error', error.message);
    })
и покажите что вывелось в косоли.




Я сделал тестовый пример и у меня отправляется все без проблем и массивы и объекты и вообще любые данные

JavaScript
1
2
3
4
5
6
7
    axios({
        method: 'post',
        url: 'http://localhost:4000/json/',
        data: [{ id: { data: [new Date("Thu, 28 Apr 2016 22:02:17 GMT")] } }, { id: "232323" }]
    }).then((response) => {
        console.log(response.data);
    })

на моем сервере

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
const express = require("express");
var bodyParser = require("body-parser");
var cors = require("cors");
const app = express();
const port = 4000;
const multer = require("multer");
app.use(
  cors({
    origin: "*",
  })
);
 
var jsonParser = bodyParser.json();
 
app.post("/json", jsonParser, (req, res) => {
  console.log("Body");
  console.dir(req.body, {depth: null})
 
  res.send({ response: "JSON!" });
});
 
app.listen(port, () => {
  console.log(`Example app listening on port ${port}`);
});
все принялось без проблем.

Code
1
2
Body
[ { id: { data: [ '2016-04-28T22:02:17.000Z' ] } }, { id: '232323' } ]
Если предполагать что ошибка в json

#1

предположим что есть какая то проблема с конвертацией или с размером json

выполни следующие действия

JavaScript
1
2
3
4
5
6
7
8
9
10
11
const inputFields = [12];
 
try{
    const inputFieldsLength = JSON.stringify(inputFields).length
    console.log("inputFieldsLength", inputFieldsLength)
 
    JSON.parse(JSON.stringify([new Date()]))
}
catch(err){
    console.log("JSON parse error: ", err.message)
}
покажи что в консоли

#2

можно попробвать использовать serialize-javascript

JavaScript
1
2
3
4
5
import serialize from "serialize-javascript";
 
sanitizeResult = JSON.parse(
                            serialize(inputFields, { isJSON: true })
                        );
и отправлять sanitizeResult.
Миниатюры
Как отправить динамическую форму в axios  
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
31.03.2023, 19:24  [ТС]
Выдал следующее:
Миниатюры
Как отправить динамическую форму в axios  
0
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
31.03.2023, 21:14
Цитата Сообщение от I am i Посмотреть сообщение
Выдал следующее:
это очень не информативно знаете ли, но в ошибке сообщается что некая переменная protocol в файле ShowAndAddWorks.js в строке 119 почему то undefined. Этой переменной в вашем коде вообще не видно, видимо это другой файл.

Вы лучше напишите что было сделано чтобы получить такую ошибку.

Добавлено через 7 минут
и напишите какие из моих советов вы попробовали, и что показывает инспектор в браузере на вкладке network
0
0 / 0 / 0
Регистрация: 28.03.2023
Сообщений: 34
01.04.2023, 15:07  [ТС]
Возможно мне бы еще стоило расписать серверную часть для понимания:

Serializer:

JavaScript
1
2
3
4
5
6
7
8
9
class WorkSerializer(serializers.ModelSerializer):
    class Meta:
        model = Work
        fields = [
            'id',
            'name_work',
            'release_dates',
            'due_dates'
        ]
Views:

JavaScript
1
2
class WorkView(viewsets.ModelViewSet):
    serializer_class = WorkSerializer
И urls.py:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
from rest_framework import routers
 
 
routerWork = routers.DefaultRouter()
 
 
routerWork.register("", WorkView, basename="workview")
 
 
urlpatterns = [
    path('work/', include((routerWork.urls, 'workview'))),
]
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.04.2023, 15:07
Помогаю со студенческими работами здесь

Подскажите как сделать динамическую форму
Добрый вечер! Есть форма: &lt;input type=&quot;checkbox&quot; name=&quot;ch1&quot;&gt; &lt;input type=&quot;text&quot; class=&quot;text&quot; name=&quot;n1&quot;&gt; &lt;input...

Как создать динамическую форму, если её родитель - вторая форма?
Как создать динамическую форму, если её родитель - вторая форма? У меня 2-е формы, первая - с кнопкой, а вторая, та, потомок которой...

Как отправить форму в БД
Как отправить мне мою форму? Перерыл инет, но не нашел ничего стоящего.... Вот форма: menu.php &lt;!DOCTYPE html&gt;

Как отправить форму на почту?
Имеются две формы: Меню ресторана в виде CheckBox и Количество блюд в виде TextBox. Нужно чтобы, кликнув на кнопку...

Как отправить данные в форму?
Всем доброго времени суток Допустим, кто-то идёт на страницу http://site.ru/pge.htm, но такой не существует. И выскакивает страница 404,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru