0

我正在制作一个简单的功能,如 w3schools 官方网站上所示。我正在尝试运行 AJAX 请求的功能。

我想这一切都很好,除了代码只在第一次失败后运行。我的意思是,假设您第一次来到我的网站,并且您第一次尝试提交,它只是刷新了页面,没有任何反应。

据我所知,我尝试使用alert每一行中的函数进行调试,以查找请求是否真的被发出。我发现readyState代码第一次运行时会从 1 跳转到 4(在每个浏览器、不同的计算机上),但下一次它将呈现 readyState 1、2、3 和 4,然后 BANG 它将工作并提交。

Javascript 函数代码(在 head 标签内)

function sendForm() {
        
    var criarRequest = new XMLHttpRequest();
    criarRequest.onreadystatechange = function() {  
        if (criarRequest.readyState == 4 && criarRequest.status == 200) {
            document.getElementById("contacts").innerHTML = criarRequest.responseText;
        } 
    };
    //var loading  = document.getElementById("contacts").innerHTML = "A enviar...";
    var inputEmail = document.getElementById("email").value;
    var inputMensagem = document.getElementById("mensagem").value;  
    criarRequest.open("POST", "sendEmail.php", true);
    criarRequest.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    criarRequest.send("email="+inputEmail+"&mensagem="+inputEmail);
}

HTML 代码表单/输入

<form>
    <input style="width:220px; height:39px" type="text" id="email" placeholder="Email" /> 
    <br  /> <br  />
    <textarea style="width:220px; height:100px" id="mensagem" placeholder="Mensagem"></textarea>
    <br  /> <br  />
    <button id="enviar" onclick="sendForm()">Enviar</button>
</form>
4

1 回答 1

8

实际上非常简单:P 您的按钮是“提交”的默认属性“类型”,当这种情况发生时,表单被提交导致刷新。添加 'type="button"' 以更改此功能,您不应再刷新允许 ajax 完成其请求。

于 2016-06-21T20:14:46.280 回答