这里有新鲜出炉的Javascript教程,程序狗速度看过来!
Javascript 是一种由Netscape的LiveScript发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
最近在学习JavaScript,因此想到使用js实现表单校验。下面通过本文给大家分享使用javascript实现表单校验功能的步骤,需要的的朋友参考下吧
文本框校验
以下是文本框的校验步骤。
1.获取待校验的文本框value值,
2.对value值设置判定条件,使用if语句或switch语句实现。
3. 若满足条件,则校验通过,返回值为true。
4. 若不满足条件则返回值为false,替换文本输出校验的提示信息。
5. 表单获取多个验证的返回值,做逻辑运算,将参数传递给表单form的onsubmit事件。
6. 在input中调用校验函数,我使用的是onblur事件触发校验函数。
下拉框校验
下拉框的校验相比文本框略有不同,下拉框中option的返回值为value,由select中的name值获取到用户的选择,因此在下拉框的校验函数中通过id获取到select中的value,在根据value值是否为空或为其余的非法值而进行不同的判断,其余的步骤也与文本框相同。
表单校验样式如下:
遇到的问题
代码块
以下为程序源码:
- <script>
- function validateUsername() {
- var input = document.myform.userName.value;
- if (input == “” || input == null) {
- document.myform.userName.focus();
- document.getElementById(“uname”).innerHTML = ”用户名不能为空 ! ”;
- return false;
- } else if (input.length > 5 || input.length < 2) {
- document.getElementById(“uname”).innerHTML = “用户名在2~5位”;
- document.myform.userName.focus();
- return false;
- } else {
- document.getElementById(“uname”).innerHTML = ”“;
- return true;
- }
- }
- function validatePassword() {
- var password = document.myform.password.value;
- if (password == “” || password == null) {
- document.getElementById(“upss”).innerHTML = “密码不能为空 ! ”;
- document.myform.password.focus();
- return false;
- } else if (password.length > 12 || password.length < 6) {
- document.getElementById(“upss”).innerHTML = “密码在6~12位”;
- document.myform.password.focus();
- return false;
- } else {
- document.getElementById(“upss”).innerHTML = “”;
- return true;
- }
- }
- function validatePasswordAgain() {
- var psw = document.myform.psw.value;
- var password = document.myform.password.value;
- if (psw != password) {
- document.getElementById(“upssa”).innerHTML = ”两次密码输入不同”;
- return false;
- } else {
- document.getElementById(“upssa”).innerHTML = “”;
- return true;
- }
- }
- function validateGroup() {
- var select = document.getElementById(“select”);
- if (select.value == “NONE”) {
- document.getElementById(“groupID”).innerHTML = ”请选择分组 ! ”;
- return false;
- } else {
- document.getElementById(“groupID”).innerHTML = ”“;
- return true;
- }
- }
- function validateForm() {
- var flag = validateUsername() && validatePassword() && validatePasswordAgain() && validateGroup();
- if (flag) {
- return true;
- } else return false;
- }
```html
- <div class="warp">
- <h1>新用户注册</h1>
- <form action="/myproject/admin/addUser" name="myform" onsubmit="return validateForm()">
- <div class="form-warp">
- <ul>
- <li>用户名称:<input class="input" type="text" name="userName" placeholder="请输入..." onblur="validateUsername()"/></li>
- <li>密 码:<input class="input" type="password" name="password" id="password" placeholder="请输入..." onblur="validatePassword()"/></li>
- <li>确认密码:<input class="input" type="password" name="psw" id="psw" placeholder="请输入..." onblur="validatePasswordAgain()"/></li>
- <li>真实姓名:<input class="input" type="text" name="realName" placeholder="请输入..."/></li>
- <li>分 组:<select name="group.id" id="select" onblur="validateGroup()">
- <option value="NONE">请选择...</option>
- <#list groups as group>
- <option value="${group.id}">${group.name}</option>
- </#list>
- </select>
- </li>
- <li><input type="submit" value="提交" id="button"/></li>
- </ul>
- <ul class="validate">
- <li id="uname"></li>
- <li id="upss"></li>
- <li id="upssa"></li>
- <li id="groupID"></li>
- </ul>
- </div>
- </form>
- </div>
- “`
总结
以上所述是小编给大家介绍的使用JavaScript进行表单校验功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对phperz网站的支持!
来源: http://www.phperz.com/article/17/0903/343908.html