0

success私のAJAX呼び出しではまったくトリガーされず、その理由がわかりません。AJAX ファイルで指定されたアラートはどれもポップアップしません。

フォーム:

<form onsubmit="check_reg();return false;" method="post" name="reg_form" id="reg">
    <label class="error" id="reg_error"></label>
    <label for="login_reg">Login</label>
    <input type="text" name="login" id="login_reg" placeholder="Login">
    <label for="email_reg">Email</label>
    <input type="text" name="email" id="email_reg" placeholder="Email">
    <label for="haslo_reg">Password</label>
    <input type="password" name="password" id="pass_reg" placeholder="Password">
    <button type="submit">Register</button>  
</form>

reg_script.php:

if (!empty($_POST['login']) && !empty($_POST['password']) && !empty($_POST['email'])) {
    $login = $mysqli->real_escape_string($_POST['login']);
    $password = $mysqli->real_escape_string($_POST['password']);
    $email = $mysqli->real_escape_string($_POST['email']);

    if ($mysqli->query("INSERT INTO users (login, password, email) VALUES('$login', '$password', '$email')")) {
        echo "ok";
    } 
    else {
        echo "error";
    }
} 
else {
    echo "empty";
}

AJAX

function check_reg() {
    $.ajax({
        url: 'reg_script.php',
        type: "POST",
        data: "login=" + $('#login_reg').val() + "&password=" + $('#pass_reg').val() + "&email=" + $('#email_reg').val(),
        success: function(result) {
            if (result == 'ok') {
                alert('ok');
            }
            else if (result == 'error') {
                alert('error');
            }
            else if (result == 'empty') {
                alert('empty');
            }
        },
    });
}

問題が何であるかについてのアイデアはありますか?

編集:このチュートリアルを使用したことを追加する必要がありました: http://developertips.net/post/display/web/3/dynamic-login-form-with-ajax-php/そして、ログインフォームを機能させることができました大丈夫です。登録フォームが機能しているだけです。

4

2 に答える 2

0

変化する

<form onsubmit="check_reg();return false;" method="post" name="reg_form" id="reg">
<label class="error" id="reg_error"></label>
<label for="login_reg">Login</label>
<input type="text" name="login" id="login_reg" placeholder="Login">
<label for="email_reg">Email</label>
<input type="text" name="email" id="email_reg" placeholder="Email">
<label for="haslo_reg">Password</label>
<input type="password" name="password" id="pass_reg" placeholder="Password">
<button type="submit">Register</button>  
</form>

に:

<form>
<label class="error" id="reg_error"></label>
<label for="login_reg">Login</label>
<input type="text" name="login" id="login_reg" placeholder="Login">
<label for="email_reg">Email</label>
<input type="text" name="email" id="email_reg" placeholder="Email">
<label for="haslo_reg">Password</label>
<input type="password" name="password" id="pass_reg" placeholder="Password">
<input type="button" onclick="check_reg()">Register</button>  
</form>

そうすれば、HTML ファイルは check_reg() を呼び出し、これが php ファイルを呼び出します。HTML ファイルに method=post などは必要ありません。この情報はすべて、関数に既に含まれています。

ところで、check_reg() 関数の data-attribute は、代わりに serializeArray() に変更することをお勧めします。

私が今気付いたもう1つのこと:

success: function(result) {

結果変数には、サーバー側 (php) からのエラー メッセージが含まれます。あなたがしなければならないことは次のとおりです。

success: function(result) {
             alert(result);
于 2013-05-16T16:45:27.903 に答える