Почему запрос Ajax прерван? - PullRequest
0 голосов
/ 16 мая 2019

Я хочу отправить запрос Ajax на сервер и получить текст HTML. Я обнаружил, что сервер успешно получает запрос и работает с БД, но Ajax-запрос прерывается в какой-то момент и не может загрузить данные. Понятия не имею, что происходит ..

JS

const listGroup = document.getElementById("list-group");

    function sendData() {
        const form = document.getElementById("create-memo-form");
        const formData = new FormData(form);
        const XHR = new XMLHttpRequest();
        let urlEncodedData;
        const urlEncodedDataPairs = [];

        for(let pair of formData) {
            urlEncodedDataPairs.push(encodeURIComponent(pair[0]) + '=' + encodeURIComponent(pair[1]));
        }

        urlEncodedData = urlEncodedDataPairs.join('&').replace(/%20/g, '+');



        XHR.addEventListener('loadstart', function() {
            console.log("loadstart");
        });
        XHR.addEventListener('load', function() {
            console.log("load");
        });
        XHR.addEventListener('loadend', function() {
            console.log("loadend");
        });
        XHR.addEventListener('progress', function() {
            console.log("progress");
        });
        XHR.addEventListener('error', function() {
            console.log("error");
        });
        XHR.addEventListener('abort', function() {
            console.log("abort");
        });

        XHR.onreadystatechange = function() {
            console.log(XHR.readyState + ' ' + XHR.status);
            if(XHR.readyState === XMLHttpRequest.DONE) {
                console.log(XHR.getAllResponseHeaders());
            }

            if (XHR.readyState === XMLHttpRequest.DONE && XHR.status === 200 ) {

                console.log(XHR.responseText);
                //listGroup.removeChild(listGroup.childNodes[0]);
                //listGroup.innerHTML = XHR.responseText + listGroup.innerHTML;
            }
        };


        XHR.open('POST', 'create-memo');

        XHR.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');

        XHR.send(urlEncodedData);
    }

createMemoForm.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<div class="list-group-item">
    <form:form modelAttribute="newMemo" id="create-memo-form">
        <form:input path="content" /><br>
        <button onclick="sendData()">Write</button><br>
        <form:errors cssClass="error" />
    </form:form>
</div>

createMemoSuccess.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<jsp:include page="createMemoForm.jsp" />
<div class="list-group-item">
    <h4 class="list-group-item-heading">${createdMemo.content}</h4>
    <div class="memo-btn-group">
        <span class="write glyphicon glyphicon-pencil"></span>
        <span class="glyphicon glyphicon-trash">Delete</span>
        <span class="label ${createdMemo.cssClass}">${createdMemo.priorityString}</span>
        <span>${createdMemo.deadline}</span>
    </div>
</div>

Контроллер

@RequestMapping("/create-memo")
    public String createMemo(Model model, @ModelAttribute("newMemo") Memo newMemo, BindingResult bindingResult, HttpSession session) {
        System.out.println("inside createMemo method");
        Member currentMember = (Member) session.getAttribute("currentMember");
        newMemo.setMemberId(currentMember.getId());
        if(memoService.addMemo(newMemo)) {
            model.addAttribute("newMemo", new Memo());
            model.addAttribute("createdMemo", newMemo);
            System.out.println("A");
            return "createMemoSuccess";
        } else {
            bindingResult.reject("create-memo-failure", "Failed to write");
            System.out.println("B");
            return "createMemoForm";
        }
    }

Консоль Firefox напечатала следующие строки:

2 0
4 0

abort 
loadend
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...