我有一个表单,用于评估我的流程页面上数据库中的信息,并在必要时返回错误。我正在使用Ajax所以它实际上不应该进入进程页面并加载我在Json中编码的内容以返回。这是我的表格加上Javascript:
<form method="post" action="../user/process_login" id="login_form">
<input type="hidden" name="action" value="login">
<label>Email Address:</label>
<input type="text" id="email" name="email" placeholder="Email" />
<label>Password:</label>
<input type="password" id="password1" name="password0" placeholder="Password" />
<input type="submit" id="submitbtn" placeholder="Submit" class="button"/>
</form>
Javascript:
<script type="text/javascript">
$(document).ready(function(){
$('#login_form').submit(function(){
$.post
(
$(this).attr('action'),
$(this).serialize(),
function(data){
if (data['errors'] == '') {
consle.log(data);
};
else{
console.log(data);
$('#alert_box').html(data);
};
},
"json"
);
return false;
});
});
</script>
以下是我的验证码的相关部分:
if (count($user) > 0 AND $decrypted_password == $this->input->post('password0'))
{
$this->session->set_userdata('user_session', $user);
$this->load->view('main.php');
}
else
{
$errors = "<div class='alert-box alert' id='error-box'><p>Your login information did not match our reccords. Try again</p></div>";
echo json_encode($errors);
}
答案 0 :(得分:0)
我认为这是因为您的代码中存在错误。我在下面指出
这里没有错误----&gt; WITHOUT ERRORS
这是错误-----&gt; WITH ERRORS
正如您所看到的,返回false确实可以正常工作。
<script type="text/javascript">
$(document).ready(function(){
$('#login_form').submit(function(){
$.post
(
$(this).attr('action'),
$(this).serialize(),
function(data){
if (data['errors'] == '') {
consle.log(data);
}; <----------------------- Error Not supposed to be there
else{
console.log(data);
$('#alert_box').html(data);
}; <----------------------- I think will still work but don't need
},
"json"
);
return false;
});
});
</script>
答案 1 :(得分:0)
您不能使用输入类型提交,在调用Ajax函数时,如果您使用它,您的代码将无法按预期工作,因此将其更改为:
<input type="button" id="submitbtn" placeholder="Submit" class="button"/>