JavaScript フォームの検証を行おうとしています。これを行うには、複数の関数を呼び出す必要があります。1 つはメールを検証するため、もう 1 つはパスワードを検証するため (これまでのところ機能しているように見えるのは 2 つだけです)、もう 1 つは性別、学年、姓、名を検証するためです。
ここに私のJavascriptコードがあります:
function emailmatch() {
var emailone = document.forms['input']['email'].value;
var emailtwo = document.forms['input']['email1bID'].value;
var passwordone = document.forms['input']['password'].value;
var passwordtwo = document.forms['input']['password1bID'].value;
if ( emailone != emailtwo ) {
alert ( "Emails do not match!" );
document.forms['input']['email'].value = '';
document.forms['input']['email1bID'].value = '';
return false;
}
else if ( passwordone != passwordtwo ) {
alert ( "Passwords do not match!" );
document.forms['input']['password'].value = '';
document.forms['input']['password1bID'].value = '';
return false;
}
return true;
}
function checkFirstname() {
var firstname = document.forms['input']['firstname'].value;
if (firstname == null) { return false; }
return true;
}
function checkLastname() {
var lastname = document.forms['input']['lastname'].value;
if (lastname == null) { return false; }
return true;
}
function checkGender() {
var gender = document.forms['input']['gender'].value;
if (gender == null) { return false; }
return true;
}
function validateform() {
var validation = true;
if ((emailmatch() && checkFirstname() && checkLastname && checkgender()) == true) return validation;
}
そして、ここにhtmlフォームがあります:
<form name="input" id="input" onSubmit="return validateform()" method="GET" action="code.php">
<tr><td>First name:</td><td> <input type="text" name="firstname" value=""></td></tr> <br />
<tr><td>Last name:</td><td> <input type="text" name="lastname" value=""></td></tr> <br />
<tr><td>Gender:</td><td> <input type="radio" name="gender" id="gender" value="male">Male <input type="radio" name="gender" value="female">Female</td></tr> <br />
<tr><td>Grade:</td><td> <input type="radio" name="grade" value="9"> 9 <input type="radio" name="grade" value="10"> 10 <input type="radio" name="grade" value="11"> 11 <input type="radio" name="grade" value="12"> 12<br /> </td></tr>
<tr><td>Email:</td><td> <input type="text" name="email" id="email" value=""></td></tr> <br />
<tr><td>Verify Email:</td><td> <input type="text" name="email1b" id="email1bID" value=""></td></tr> <br />
<tr><td>Password:</td><td> <input type="password" name="password" id="password" value=""></td></tr> <br />
<tr><td>Verify Password:</td><td> <input type="password" name="password1b" id="password1bID" value=""></td></tr> <br />
<tr><td colspan="2"><center><input type="submit" value="Submit"></center></td></tr>
</form>
全体として、すべての関数を作成し、送信時にそれらすべてを呼び出す関数も作成しましたが、実際に機能しているのは電子メールとパスワードだけです。それをデータベースに入力するコードを呼び出します(これも機能しています)ので、それは問題ではありません。検証コードはどこで間違っていますか?