入力内容が条件と合わなかったら送信できないようにしたい
javascriptを使ってログイン機能を作っています。
ユーザーが入力した内容に不備があればエラーメッセージを出力してデータを送信しないようにしたいです。
HTMLのonsubmitで各入力フォームがtrueでなかった場合にエラーメッセージを出力して送信を止める処理が書きたいです。
発生している問題・エラーメッセージ
入力してもユーザー名以外エラーメッセージが上手く出力されません
エラーメッセージ
該当のソースコード
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <article> <p id="add-user">ユーザー登録</p> <form method="get" id="user-text" onsubmit="return (nameCheck()&&mailCheck()&&passCheck()&&passCheck2())"> <input type="text" id="name" placeholder="ユーザー名"> <p id="name_p"></p> <input type="text" id="mail" placeholder="メールアドレス"> <p id="mail_p"></p> <input type="text" id="pass" placeholder="パスワード"> <p id="pass_p"></p> <input type="text" id="Pass2" placeholder="パスワード(確認)"> <p id="pass_p2"></p> <input id="button" type="submit" value="ユーザー登録"> </form> </article> <script> function nameCheck(){ let name=document.getElementById("name"); let nameP=document.getElementById("name_p"); let regName = "/^[^a-zA-Z0-9]*$/g"; if(name.value===""){ nameP.innerHTML="名前を入力して下さい"; return false; }else if(name.length >= 8){ nameP.innerHTML="8文字以内で入力して下さい"; return false; }else if(name.value.match(regName)===null){ nameP.innerHTML("英数字以外で入力して下さい"); return false; }else{ return true; } } function mailCheck(){ let mail = document.getElementById("mail"); let mailP = document.getElementById("mail_p"); if(mail.value === ""){ mailP.innerHTML="メールアドレスを入力して下さい"; return false; } } function passCheck(){ let pass = document.getElementById("pass"); let passP = document.getElementById("pass_p"); if(pass.value === ""){ passP.innerHTML="パスワードを入力して下さい"; return false; } } function passCheck2(){ let pass2 = document.getElementById("pass2"); let passP2 = document.getElementById("pass_p2"); if(pass2.value===pass.length){ passP2.innerHTML="パスワードが違います"; return false; } } </script> </body> </html>
試したこと
formタグのonsubmitの書き方が悪いかと思い調べましたがわかりません
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/02/08 13:30