Node.js/Express, как изменить данные, полученные при вводе формы флажка

У меня есть список элементов флажка ввода, отображаемых с помощью рулей

<form method="POST" action='/processImages'>
                        <input type='checkbox' id='.DS_Store' name='.DS_Store' />
                            <p>.DS_Store</p>
                        <input type='checkbox' id='.localized' name='.localized' />
                            <p>.localized</p>
                        <input type='checkbox' id='Courses' name='Courses' />
                            <p>Courses</p>
                        <input type='checkbox' id='Home' name='Home' />
                            <p>Home</p>
                    
<input type="submit" value="run">
         

и я хочу передать имена другой функции или отобразить их имена по другому пути С этим кодом:

const processRouter = express.Router()

const processRouter = express.Router()
processRouter.post('/', async (req, res, next) => {
    const test =(req.body) 
    res.send(test)
})

app.use('/processImages', processRouter)

что я получаю:

{"Курсы":"на","Главная":"на"}

Но я хочу получить только такие имена, как {"Курсы", "Дом"} Как избавиться от этого «вкл» для каждого элемента, я предполагаю, что это происходит из флажка типа ввода.

Я новичок, и я не могу понять, как я должен запрашивать только «имена». Спасибо

Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Сравнение структур данных: Массивы и объекты в Javascript
Сравнение структур данных: Массивы и объекты в Javascript
Итак, вы изучили основы JavaScript и хотите перейти к изучению структур данных. Мотивация для изучения/понимания Структур данных может быть разной,...
Создание собственной системы электронной коммерции на базе Keystone.js - настройка среды и базовые модели
Создание собственной системы электронной коммерции на базе Keystone.js - настройка среды и базовые модели
Прошлая статья была первой из цикла статей о создании системы электронной коммерции с использованием Keystone.js, и она была посвящена главным образом...
Приложение для отслеживания бюджета на React js для начинающих
Приложение для отслеживания бюджета на React js для начинающих
Обучение на практике - это проверенная тема для достижения успеха в любой области. Если вы знаете контекст фразы "Практика делает человека...
Стоит ли использовать React в 2022 году?
Стоит ли использовать React в 2022 году?
В 2022 году мы все слышим о трендах фронтенда (React, Vue), но мы не знаем, почему мы должны использовать эти фреймворки, когда их использовать, а...
0
0
20
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Невозможно получить {"Courses", "Home"}, потому что это недопустимый формат JSON. Однако вместо этого вы можете передать массив ["Courses", "Home"] через запрос.

Если запрос, который отправляет ваша форма, вам не нужен, рассмотрите возможность написания собственной функции onSubmit для обработки вызова AJAX.


Тем не менее, есть ли особая причина, по которой вы хотите изменить запрос? Вы можете проанализировать исходный формат, чтобы получить то, что вы хотите:

function iterate(input) {
    //Example input: {"Courses":"on","Home":"on"}

    const arr = [];

    Object.entries(input).forEach(function ([key, value], index) {
        console.log(key, value, index);
        if (value === "on")
            arr.push(key);
    });

    return arr;
}

console.log(iterate({ "Courses": "on", "Home": "on" }));
console.log(iterate({ "Courses": "on", "Home": "off" }));

Просто решил это через 10 минут после публикации вопроса... processRouter.post('/', async (req, res, next) => { const test =(req.body) console.log( Object.keys(test)) res.send( ***Object.keys***(test)) }) сработало простое object.key

rwats 09.04.2022 19:44

Звучит хорошо для меня - если вы хотите обработать случай, когда он показывает «выключено», вы можете использовать код, который я только что обновил в своем ответе. Удачи с остальными.

Shaan K 09.04.2022 19:46

Другие вопросы по теме