Ajax和php,导致div

时间:2015-03-26 14:08:34

标签: javascript php jquery ajax

我想在“result”div中显示我的服务器页面的结果。 这是我的计划:

home.php

 <script src="myscripts.js"></script>
 <div id="loginform">
   <div id="result"></div>
   <?php include_once 'core.login.php'; ?>
 </div>

myscripts.js

$(document).ready(function() {
$('#login').submit(function() { // catch the form's submit event
$.ajax({ // create an AJAX call...
    data: $(this).serialize(), // get the form data
    type: $(this).attr('method'), // GET or POST
    url: $(this).attr('action'), // the file to call
    success: function(response) { // on success..
        $('#result').html(response); // update the DIV
    }
});
return false; // cancel original event to prevent form submitting
    });
});

core.login.php

<?php

 // stuff about $db variable e other stupid things like $tool = new Tools etc...

 $email = $_POST["email"];
 $password = $_POST["password"];

// Initializing login process
if (isset($email) or isset($password)) {
$tool->decode($email, $password, $db);
}

?>

 <form action="core.login.php" method="POST" id="login">
        <fieldset>
            <legend>Data login:</legend>
            Email:<input id="email" type="email" name="email" placeholder="someone@example.com" required>
            <br>
            Password:<input id="password" type="password" name="password" required>
            <br>
            <input type="submit" value="Submit">
        </fieldset>
 </form>

class.php

public function decode($email, $password, $db) {
    if ($stmt = $db->prepare("SELECT password FROM users WHERE email = ?")) {
        $stmt->bind_param('s', $email);
        $stmt->execute();
        $stmt->store_result();
        $stmt->bind_result($password_db);
        $stmt->fetch();
        if ($stmt->num_rows == 1) {
            if ($password == $password_db) {
                echo "Success"; 
            } else {
                echo "Error";      
            }
        } else {
            echo "Email didn't found!";
        }
    }
}

如果没有AJAX,如果我正常启动代码它会工作,它会给我正确的回声结果(成功或错误)但是当我使用AJAX时,没有任何反应。

更新

好的问题是动作网址,我的核心文件位于core / core.login.php文件夹中,现在它显示了结果div中的页面,但页面核心现在显示了这个: 致命错误:在第9行的网站上的非对象上调用成员函数decode()

也许ajax不传递像object这样的变量?

2 个答案:

答案 0 :(得分:0)

在js文件中尝试使用它:

 (Or Document)
$('#loginform').on('submit', '#login', function() {
  //AJAX etc..
})

而不是:

$('#login').submit(function() {
       //AJAX etc..
}

答案 1 :(得分:0)

试试这个js

$(document).ready(function() {
$('#login').submit(function() { // catch the form's submit event
$.ajax({ // create an AJAX call...
data: $("#login").serialize(), // get the form data
type: $(#login).attr('method'), // GET or POST
url: $(#login).attr('action'), // the file to call
success: function(response) { // on success..
    $('#result').html(response); // update the DIV
}
});
 return false; // cancel original event to prevent form submitting
   });
 });