@Nikita1244
Anonymous

Почему сервер получает пустые данные?

Всем привет. Написал такой код для страницы:

<template>
    <main class="main">
        <div class="admin-panel">
            <h1 class="admin-panel__title">Создание поста</h1>
            <form class="admin-panel__form" @submit.prevent>
            <input type="text" v-model="post.title">
            <textarea class="admin-panel__textarea" v-model="post.text"></textarea>
            <input type="submit" @click="sendFormData()">
            </form>
        </div>
    </main>
</template>

<script>
import axios from 'axios'
export default {
    name: "AdminPanel",
    data() {
        return {
            post: {
                title: '',
                text: '',
            },   
        }
    },
    methods: {
        sendFormData() {
            const data = JSON.stringify(this.post);
            axios.post('http://localhost:5000/api/create-post', () => {
                body: data
            })
            .then((response) => {
                console.log(response);
            })
        }
    }
}

</script>

<style scoped>
.main {
    min-height: 100vh;
    min-width: 100vw;
    background-color: #1D1C18;
}

.admin-panel__title {
    font-size: 24px;
    color: #FFF;
    padding: 20px 0 0;
    margin: 0;
    text-align: center;
}

.admin-panel__button {
    width: 100px;
    height: 30px;
    color: aqua;
    font-size: 16px;
}
</style>


Необходимо отправить запрос на сервер, чтобы он эти данные внес в БД MongoDB.
Но сервер почему-то получает пустые данные. Почему?
  • Вопрос задан
  • 78 просмотров
Решения вопроса 1
Aetae
@Aetae Куратор тега Vue.js
Тлен
Откуда ты эту хрень взял?
axios.post('http://localhost:5000/api/create-post', () => {
  body: data
})
Во-первых: axios принимает параметром объект, а не функцию возвращающую объект.
Во-вторых: axios.post вообще сразу принимает body:
axios.post('http://localhost:5000/api/create-post', data)

В-третьих: даже если бы оно принимало функцию(что не так) - конструкция
() => {
  body: data
}
на самом деле расшифровывается так:
() => { // начало блока кода
  // метка body указывающий на висящую в воздухе переменную data
  body: data
  // никакого возврата из функции
} // конец блока кода
чтобы оно воспринималось как объект, можно, например, заключать в скобки:
() => ({
  body: data
})
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы