我正在使用 jquery+Ajax 验证重复名称。一切正常,只是一旦一切都返回true,表单就没有提交
发生了什么
- 如果未输入名称,则会显示警告框,说明需要名称 --> 此处没问题
- 如果发现重复的名称,则会出现警告框,说明名称已存在且表单未提交 --> 此处没问题
- 如果没有找到重复的名称,则会出现警告框(以证明
else
部分条件有效),但表单不提交。我希望表单继续并在这else
部分提交自己
jQuery 代码
$('#form1').submit(function(){
var name = $('#shelf_name').val();
if(name == '')
{
alert('Shelf name is required');
$('#shelf_name').focus();
}
else
{
$.ajax({
type:'post',
url:'check-duplicate-shelf-name.php',
data:{'name':name},
context:this,
success:function(data)
{
if(data == 'stop')
{
alert('Shelf name already exists'); // working if duplicate name is found
}
else
{
alert('else working?'); // alert box is showing up if name is not duplicate
this.submit(); // but after alert, this line not executing
}
}
});
}
return false;
});
HTML 表单标签
<form action="add-shelf-post.php" method="post" id="form1">
check-duplicate-shelf-name.php页面
<?php
include 'confignew.php';
$name = $_POST['name'];
// peforming database operations
.
.
.
// and then
if($db->num_rows($q) == 0)
{
echo 'go';
}
else
{
echo 'stop';
}
我错过了一些非常明显的东西。希望这里有人可以指出这一点。
在 Firefox 中使用 Firebug 检查后,我确实遇到了错误。当我使用 Chrome 进行测试时,它没有出现。这是屏幕截图。