我想用下面的代码添加一个新的方法到jQuery验证插件。我的目标是检查电子邮件地址是否已经存在于数据库(MySQL)中。如果是,它会通知用户注册另一个电子邮件地址。不知何故,总是返回的结果是“电子邮件已被采纳”。jQuery验证插件addMethod
这些都是validate.js代码:
$(document).ready(function(){
$.validator.addMethod("uniqueEmail", function(value, element) {
$.ajax({
type: "POST",
url: "availability.php",
data: value,
success: function(exist)
{
if(exist>0) {
return true;
} return false;
}
});
} ,"Email is already taken");
$('#signup form').validate({
rules: {
firstname: {
required: true,
minlength:3
},
lastname: {
required: true,
minlength: 3
},
affiliation: {
required: true,
},
occupation: {
required: true,
},
email: {
required: true,
email: true,
uniqueEmail: true
},
password: {
minlength: 6,
required: true
},
repassword: {
equalTo: "#password"
}
},
messages: {
firstname: {
minlength: "Your first name should be more than 3 characters"
},
lastname: {
minlength: "Your last name should be more than 3 characters"
},
},
success: function(label) {
label.text('OK!').addClass('valid');
}
});
});
而这些都是在我的PHP文件中的代码:
<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/braddclient/includes/magicquotes.inc.php';
include $_SERVER['DOCUMENT_ROOT'] . '/braddclient/includes/db.inc.php';
$email = strtolower($_POST['email']);
$email = mysqli_real_escape_string($link, $email);
$sql = "SELECT * FROM bradduser WHERE email='$email'";
$result = mysqli_query($link, $sql);
$num = mysqli_num_rows($result);
echo $num;
?>
对于这个例子有问题的人,我遇到了服务器端语言的响应问题,所以我设法通过直接在插件中从'ajax'的'dataType'来解决它'dataType:“json”'到'dataType:“text”'on line 1206' – CIRCLE 2014-05-29 11:48:07