Я создал пользовательское правило проверки с именем «uniqueUserName». Я использую его для проверки поля ввода username_ID в моей форме. Проблема в том, что это не срабатывает. В Firebug я вижу, что на сервер не отправляется запрос, что произойдет при срабатывании правила.
Форма, которую я хочу проверить, динамически загружается в div.
Мои сценарии:
$(document).ready(function() {
//First. load the form and add it to the div.
$.get("registeraccount.php", function(data){
$("#adminarea").html(data);
//addValMeth();
attacheValidation("#registerform");
});
//function addValMeth(){
//Add custom validator rule
$.validator.addMethod("uniqueUserName", function(value, element) {
$.get("databasescripts/validate_username.php", {username: value}, function(data2){
if(data2 == "1"){
return true ;
}else{
return false;
}
});
}, "Användarnamnet är inte unikt");
//};
$("#registerform").live("submit", function(e){
//Prevent the form from submitting normally
e.preventDefault();
$.post("registeraccount.php",$(this).serialize(),function(msg){
});
});
function attacheValidation($form){
//Define validation rules
$($form).validate({
rules: {
firstname: "required",// simple rule, converted to {required:true}
surname: "required",
//phonenumber: "required",
address: "required",
// address2: "required",
zipcode: "required",
//username_ID: "return true;",
city: "required",
email: {// compound rule
required: true,
email: true
},
username_ID: {
required: true,
uniqueUserName: true
}
},
messages: {
firstname: "Förnamn saknas" ,
surname: "Efternamn saknas",
address: "Adress saknas",
zipcode: "Postkod saknas",
city: "Ort saknas",
companyname: "Företagsnamn saknas",
email: "Korrekt emailadress saknas"
}
});
};
});
Моя форма:
<form id='registerform' action='registeraccount.php' method='post'>
Ägare av konto</br>
* Förnamn: <input type='text' name='firstname' /> <br/>
* Efternamn: <input type='text' name='surname' /> <br/>
* Email: <input type='text' name='email' /> <br/>
* Telefon: <input type='text' name='phonenumber' /> <br/>
Företagsinformation: </br>
* Adress: <input type='text' name='address' /> <br/>
Adress: <input type='text' name='address2' /> <br/>
* Postnummer: <input type='text' name='zipcode' /> <br/>
* Ort: <input type='text' name='city' /> <br/>
<br/>
Kontoinformation</br>
<div id='username_message'></div>
* Användarnamn: <input id='username_ID' type='text' name='username' />
<br/>
Företagsinformation<br/>
* Företagsnamn (som kunden kommer se det): <input type='text' name='companyname' /> <br/>
Organisationsnummer: <input type='text' name='organisationnumber' /><br/>
<input id='submitaccountregistration' type='submit' value='Submit Comment' />
</form>
Как видите, я попытался загрузить новый метод проверки, когда форма была загружена, вызывая функцию (addValMeth). Нет разницы. Я прокомментировал эту функциональность без какого-либо другого поведения.
По какой причине пользовательское правило не сработало и как его решить? Все остальные правила работают правильно.