簡體   English   中英

通過ajax發送POST請求時出錯

[英]error while sending POST request via ajax

我想發送發布請求並從php文件中獲取回顯。 但是我找不到我的錯誤,總是會得到通知:未定義的索引...

請不要jQuery ...

<form id="register" method="POST" action="register-action.php">

    <input type="text" name="first_name" placeholder="Onoma"><br>
    <input type="text" name="last_name" placeholder="Epitheto"><br>
    <input type="text" name="mail" placeholder="E-mail"><br>
    <input type="password" name="pass" placeholder="password"><br>

    <select name="eidikotita_id">
        <?php while($eid = $eidikotites->fetch( PDO::FETCH_ASSOC )):
            echo "<option value={$eid['id_eidikotitas']}>{$eid['titlos']}</option>";
        endwhile; ?>
    </select>

    <input type="submit" value="Register"><br>
</form>

///////////////////////////////////////////////////// /////////////

var mail_input = document.querySelector("#registerinput[name='mail']").value;
alert(mail_input);
document.querySelector("#register input[name='first_name']").focus();
document.querySelector("#register input[name='mail']").onblur = function() {

var request = new XMLHttpRequest();//instantiate an XMLHttpRequest object
request.open("POST", "register-action.php", true);//Specifying the Request
request.setRequestHeader("Content-Type", "text/plain");//POST requests,for example, need a “Content-Type” header
request.send(mail_input);//specify the optional request body. GET requests never have a body, so you should pass null or omit the argument.
};

///////////////////////////////////////////////////// ////////////////////////////

<?php 
echo $_POST['mail'];
?>

只需print_r() POST數據即可查看問題所在。

xhr.send()應該看起來像這樣: xhr.send('mail=' + encodeURIComponent(email))因為您想要$_POST['mail'] 您的選擇器還存在一個問題,該問題應為"#register input[name='mail']"

document.querySelector("#register input[name='first_name']").focus();
document.querySelector("#register input[name='mail']").onblur = function() {

    var mail_input = document.querySelector("#register input[name='mail']").value;
    var request = new XMLHttpRequest();//instantiate an XMLHttpRequest object
    request.open("GET", "register-action.php?mail="+mail_input, true);//Specifying the Request
    request.setRequestHeader("Content-Type", "text/plain");//POST requests,for example, need a “Content-Type” header
    request.send(encodeURIComponent(mail_input));//specify the optional request body. GET requests never have a body, so you should pass null or omit the argument.
//////send succcess

    if (request.readyState === 4 && request.status === 200) {
        request.onreadystatechange = function(){
        console.log(request.responseText);      
        }
    }   
};

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM