JavaWeb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证)
程序员文章站
2022-07-05 20:45:57
问题:表单怎么在输入后立即验证,而不是提交后再验证那么不方便(网上搜到的要么是模棱两可,要么是残缺不全…)
方法:鉴于此,加上我个人的理解(注释)在上面。
截图:...
问题:表单怎么在输入后立即验证,而不是提交后再验证那么不方便(网上搜到的要么是模棱两可,要么是残缺不全…)
方法:鉴于此,加上我个人的理解(注释)在上面。
截图:
代码:
<!doctype html> <html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <title>用户注册</title> <!-- 此处引用外部css样式 --> <link rel="stylesheet" href="css/style.css" rel="external nofollow" /> <script type="text/javascript"> //及时验证用户名 function checkuse(){ //在每个函数中定义check变量是为了在表单提交后,能够逐个验证每个函数是否通过,很好很好。(以下同理) var check; var username = document.getelementbyid("username").value; if (username.length > 18 || username.length < 6) { alert("用户名输入不合法,请重新输入!"); //此处甚妙,既然你在此处输入错误,那么按理说当然要在此处继续输入了。(在此处继续获取焦点!) document.getelementbyid("username").focus(); check = false; } else { document.getelementbyid("checktext1").innerhtml = "* 用户名由6-18位字符组成 √"; check = true; } return check; } //利用正则表达式判断密码符合否 function checkpwd() { var check; var reg = /[^a-za-z0-9_]+/; var regs = /^[a-za-z0-9_\u4e00-\u9fa5] + $ /; var password = document.getelementbyid("password").value; if (password.length < 6 || password.length > 18 || regs.test(password)) { alert("密码输入不合法,请重新输入!"); document.getelementbyid("password").focus(); check = false; } else { document.getelementbyid("checktext2").innerhtml = "* 密码由6-18位字符组成,且必须包含字母、数字和标点符号 √"; check = true; } return check; } //验证密码是否不一致! function checkpwdc() { var check; var password = document.getelementbyid("password").value; var pwdc = document.getelementbyid("pwdc").value; if (password != pwdc) { alert("两次输入密码不一致,请重新输入!"); document.getelementbyid("pwdc").focus(); check = false; } else { document.getelementbyid("checktext3").innerhtml = "* 请再次输入你的密码 √"; check = true; } return check; } //提交时验证用户类别 function checkut(){ var check; if(document.getelementbyid("seluser").selectedindex == 0) { alert("请选择用户类型!"); document.getelementbyid("seluser").focus(); check = false; }else{ document.getelementbyid("checktext4").innerhtml = "* 请选择用户类型 √"; check = true; } return check; } //提交时验证用户性别 function checkgender(){ var check; var gender = ""; //获取所有名称为sex的标签 var sex = document.getelementsbyname("sex"); //遍历这些名称为sex的标签 for(var i=0;i<sex.length;++i){ //如果某个sex被选中,则记录 if(sex[i].checked) gender = sex[i].value; } if(gender == "") { alert("请选择性别!"); check = false; }else{ document.getelementbyid("checktext5").innerhtml = "* 请选择你的性别 √"; check = true; } return check; } //及时验证出生日期 function checkdate(){ var check; if(document.getelementbyid("txtdate").value ==""){ alert("请填写出生日期!"); document.getelementbyid("txtdate").focus(); check = false; }else{ document.getelementbyid("checktext6").innerhtml = "* 请选择你的出生日期 √"; check = true; } return check; } //及时验证兴趣爱好 function checkhobby(){ var check; var hobby = 0; //objnum为所有名称为hobby的input标签 var objnum = document.getelementsbyname("hobby"); //遍历所有hobby标签 for(var i=0;i<objnum.length;++i){ //判断某个hobby标签是否被选中 if(objnum[i].checked==true) hobby++; } //如果有选中的hobby标签 if(hobby >=1){ document.getelementbyid("checktext7").innerhtml = "* 请选择你的兴趣爱好 √"; check = true; }else{ alert("请填写爱好!"); check = false; } return check; } //正则表达式验证电子邮件(及时) function checkemail(){ var check; //电子邮件的正则表达式 var e1 = document.getelementbyid("email").value.indexof("@",0); var e2 = document.getelementbyid("email").value.indexof(".",0); if(email == "" || (e1==-1 || e2==-1) || e2<e1 ) { alert("e_mail输入错误!"); document.getelementbyid("email").focus(); check = false; } else { document.getelementbyid("checktext8").innerhtml = "* 请填写常用的email,将用于密码找回 √"; check = true; } return check; } //及时验证自我介绍 function checkintro(){ var check; var intro = document.getelementbyid("introduction").value; if (intro.length > 100) { alert("字数超限!"); check = false; } else { document.getelementbyid("checktext9").innerhtml = "* 限100字内 √"; document.getelementbyid("checktext9").focus(); check = true; } return check; } //提交表单时所有都验证一遍(若任何一个验证不通过,则返回为false,阻止表单提交) function check() { var check = checkuse() && checkpwd() && checkpwdc() && checkut() && checkgender() && checkdate() && checkhobby() && checkemail() &&checkintro(); return check; } </script> </head> <body > <!-- <form action ="跳转页面" method ="get"|"post" name ="表单名称" target ="打开方式" enctype="multipart/form-data" > --> <!-- onsubmit()函数在返回值为true时提交表单。 --> <form action="#" method="get" onsubmit="return check()" > <fieldset> <legend> 表单及时验证小例子 </legend> <table align="left" style="background-image: url('img/4.jpg');" > <tr> <td>用户名:</td> <td><input type="text" name="username" id="username" onchange=" checkuse()" /></td> <td id="checktext1">* 用户名由6-18位字符组成</td> </tr> <!-- onblur 事件处理程序:当元素或窗口失去焦点时触发该事件 --> <!-- onchange事件处理程序:当表单元素获取焦点,并且内容发生改变时,触发该事件 --> <!-- 以下同理 --> <tr> <td>密码:</td> <td><input type="password" name="password" id="password" onchange="checkpwd()" /></td> <td id="checktext2">* 密码由6-18位字符组成,且必须包含字母、数字和标点符号</td> </tr> <tr> <td>确认密码:</td> <td><input type="password" name="pwdc" id="pwdc" onchange="checkpwdc()" /></td> <td id="checktext3">* 请再次输入你的密码</td> </tr> <tr> <td>用户类型:</td> <td> <select id="seluser" onblur="checkut()"> <option name="seluser" value="0">请选择</option> <option name="seluser" value="1">管理员</option> <option name="seluser" value="2">普通用户</option> </select> </td> <td id="checktext4">* 请选择用户类型</td> </tr> <tr> <td>性别:</td> <td> <input type="radio" value="1" name="sex" onchange="checkgender()"/>男 <input type="radio" value="2" name="sex" onchange="checkgender()"/>女 </td> <td id="checktext5">* 请选择你的性别</td> </tr> <tr> <td>出生日期:</td> <td><input type="date" name="date" id="txtdate" onblur="checkdate()"/></td> <td id="checktext6">* 请选择你的出生日期</td> </tr> <tr> <td>兴趣爱好:</td> <td> <input type="checkbox" name="hobby" value="reading" onchange="checkhobby()">阅读 <input type="checkbox" name="hobby" value="music" onchange="checkhobby()">音乐 <input type="checkbox" name="hobby" value="sports" onchange="checkhobby()">运动 </td> <td id="checktext7">* 请选择你的兴趣爱好</td> </tr> <tr> <td>电子邮件:</td> <td><input type="text" name="email" id="email" onchange="checkemail()"/></td> <td id="checktext8">* 请填写常用的email,将用于密码找回</td> </tr> <tr> <td>自我介绍:</td> <td><textarea cols="30" rows="3" name="introduction" id="introduction" onchange="checkintro()">这是自我介绍...</textarea></td> <td id="checktext9">* 限100字内</td> </tr> <tr> <td colspan="2" align="center"> <input type="submit" name="submit" value="提交" /> <input type="reset" name="reset" value="重置" /> </td> </tr> </table> </fieldset> </form> </body> </html>
css样式:
input:focus,textarea:focus{ border:1px solid #f00; background:#fcc; } textarea{ width:230px; height:50px; } body { font-size:15px; /* 字体的样式 */ font-family:microsoft yahei; } select option{ font-size:10px; font-family:microsoft yahei; }
以上所述是小编给大家介绍的javaweb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证),希望对大家有所帮助
上一篇: 基于pako.js实现gzip的压缩和解压功能示例
下一篇: jquery与js实现全选功能的区别