У меня есть эта начальная HTML-форма, в которой пользователь пишет имя наставника, и я хочу сделать POST, нажав кнопку, но конечная точка никогда не обновляется с новым именем
<form>
<div class = "form-group">
<label for = "exampleInputEmail1">Mentor Name</label>
<input type = "text" class = "form-control" id = "mentor-input" aria-describedby = "emailHelp">
<button type = "submit" class = "btn btn-primary" id = "btn-submit">Submit</button>
</form>
//Here is my object
let mentor = {
name: ""
}
document.getElementById("mentor-input").addEventListener("keyup", (event)=> {
let inputValue = event.target.value
mentor.name= inputValue
}
)
document.getElementById("btn-submit").addEventListener("click",()=> {
let xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function () {
if (this.readyState == 4 && this.status == 200) {
let response = xhttp.responseText;
};
xhttp.open("POST", `https://ajaxclass-1ca34.firebaseio.com/11g/JavADv/mentors.json`, true);
xhttp.send(JSON.stringify(mentor));
}
})
@ Teemu - Почему? Есть ли у вас какие-то основания полагать, что конечная точка ожидает полезную нагрузку данных из нескольких частей вместо полезной нагрузки JSON?
@JavoADv - вы не показали нам серверный код, отвечающий за обработку запроса POST. У нас нет возможности узнать, почему он не обновляет данные, которые вы ему отправляете.
Ждать! URL: https://ajaxclass-1ca34.firebaseio.com/11g/JavADv/mentors.json, вы ожидаете, что файл json автоматически обработает запрос?
@ Teemu, я этого не ожидал, просто не знаю, как это сделать = (
Что ж, тогда вам нужно предоставить некоторые подробности о своей серверной части. Файл json - это просто текст, он не может обрабатывать запрос POST, вам понадобится какая-то программа на стороне сервера, чтобы прочитать данные, а затем записать их в файл.
Я попытаюсь получить подробную информацию о серверной части, которую вы просите, а затем я поделюсь. Спасибо!



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Вы должны создать FormData объект на основе формы и отправить его вместо JSON. Можно выполнить отправлять данные как JSON, но это требует еще некоторой работы.