这是非常具体的,我还没有找到答案 我正在编写一个脚本来检查是否已使用JQuery $ .POST将名称输入到SQL服务器中。
前端看起来像这样:
register.php
<div id="container" class="container">
<div id="wrapper" class="wrapper">
<div id="title" class="title">
Welcome to Taskar!
</div>
<div id="login" class="login">
<form method="post" action="registermembers.php">
<div id="exists">
Register Your Company Below:
</div>
<input type="text" id="company" name="company" value="Company Name"/> <br />
<br />
<input type="text" id="password" name="password" value="Default Password"/> <br />
<input type="submit" name="submitcompany" value="Submit" />
</form>
<script>
$(document).ready(function() {
$('#company').keyup(function() {
var $company = $(this).val();
var $reg = $('#exists').html();
$.post('include/reg_post.php', { company: $company, reg: $reg }, function(company) {
$('#exists').html(company);
});
});
});
</script>
</div>
</div>
</div>
后端代码如下所示:
reg_post.php
<?php
include 'include/db.php';
$reg = $_POST['reg'];
$company = $_POST['company'];
$email_hash = $_COOKIE['email_hash'];
$password = $_COOKIE['password'];
$sql = "SELECT * FROM taskar_employee WHERE (company = '$company')";
$result = mysql_query($sql) or die(mysql_error());
if(mysql_num_rows($result) <= 1){
echo $reg;
} else {
echo "This Company Already Exists!";
} ?>
现在,我遇到的问题是,当我测试它时,它一直工作正常,直到我输入数据库中的公司名称。它告诉我,该公司已经注册。当我按退格键或键入另一个字母时,它仍然告诉我该公司仍然存在,但显然不会。
似乎if语句想要在获得相反的声明后停止$ .post功能继续?
你们有什么想法?
答案 0 :(得分:2)
您的问题在于您使用$reg
变量的方式。
$reg
包含#exists
div的HTML内容,因此它首先是“在下面注册您的公司”。但是,一旦你找到了确实存在的公司名称,就用“已经存在的公司”替换该HTML。从那时起,$reg
,在JavaScript和PHP方面,总是“这家公司已经存在!” (因为你总是在你的POST中传递$reg
。)
如果该div的内容根本没有传递给PHP代码或由PHP代码处理,那可能会容易得多。如果公司存在,那么你的PHP脚本只返回“1”,如果不存在则返回“0”(或其他一些同样简单的标志),这会更简单。
然后,在JavaScript方面,您可以这样做:
$.post('include/reg_post.php', { company: $company }, function(exists) {
var message;
if (exists === '1') {
message = 'This Company Already Exists!';
}
else {
message = 'Register Your Company Below:';
}
$('#exists').html(message);
});
答案 1 :(得分:1)
如果找不到公司,您将通过$('#exists').html();
返回。问题是,如果找到公司,则替换#exists
内的html。然后,当你下次调用帖子时,你将这个文本传回去,所以在这种情况下:
if(mysql_num_rows($result) <= 1){
echo $reg;
} else {
echo "This Company Already Exists!";
}
您的$reg
现已设置为This Company Already Exists!
,因此无论发生什么情况,您都会返回该文字。