对于JavaScript而言,进行表单数据的验证可谓是很有必要的,而且一般我们都会在网页上先进行一下表单验证,然后服务器端再次进行验证,来确保用户提交数据的准确性。下面就来分享一个JQuery实现的表单验证。


本文的大纲为:


制作表单

  • 要想实现表单验证,前提是得有个表单了。
<form method="post" action="">
            <fieldset>
                <legend>表单详情</legend>
                <div class="int">
                    <label for="username">用户名:</label>
                    <input type="text" id="username" class="required" />
                </div>
                <div class="int">
                    <label for="email">邮&nbsp;箱:</label>
                    <input type="email" id="email" class="required">
                </div>
                <div class="int">
                    <label for="persininfo">个人资料</label>
                    <textarea type="text" id="personinfo" ></textarea>
                </div>
                <div class="sub">
                    <input type="submit" value="提交" id="send">
                    <input type="reset" id="res">
                </div>
            </fieldset>
        </form>

得到的界面如下:

  • 小红点?

    想必眼睛雪亮的你一经发现了后面的小红点,这就是我们定义了input标签里面required类属性值的原因,这样可以显得我们的表单更加的人性化,更加的美观。

    使用到的JQuery代码如下:

    // 首先添加非空验证小红点
    $("form :input.required").each(function(){
        var $required = $("<strong class='high'>*</strong>");
        $(this).parent().append($required);
    });

正式的表单验证

  • 使用markdown的流程图进行演示吧,思路如下
  • 使用JQuery也是比较简单的,只要是思路有了,剩下的就是些语法问题。
// 下面添加每个元素的特定的验证规则
        $("form :input").blur(function(){
            var $parent = $(this).parent();
            // 验证用户名
            if($(this).is("#username")){
                if(this.value=="" || this.value.length<6){
                    var errmsg = "请至少输入6位的用户名!";
                    $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    var rightmsg = "输入数据正确!";
                    $parent.append("<span>"+rightmsg+"</span>");
                }
            }

            // 验证邮箱
            if($(this).is("#email")){
                if(this.value==""|| (this.value!=""&& !/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value))){
                    var errmsg = "请输入正确的邮箱格式!";
                    $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    var rightmsg = "输入正确!";
                    // $parent.append("<span>"+rightmsg+"</span>");
                    $parent.append("<span>"+rightmsg+"</span>");
                }
            }
        });
  • 界面效果

优化效果

现在出错提示已经有了,但是如果我们修正了input标签里面的数据,错误提示仍然会存在,所以我们需要在其失去鼠标焦点的时候将出错的提示语句删掉。所以我们需要为form :input.required标签们添加一个blur事件。

// 失去焦点之后删除之前的数据提示
        $("form :input.required").blur(function(){
            var $parent = $(this).parent();
            // $parent.find(".error").remove();
            if($(this).is("#username")){
                if(this.value=="" || this.value.length<6){
                    // var errmsg = "请至少输入6位的用户名!";
                    // $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    $parent.find(".error").remove();
                }
            }

            // 验证邮箱
            if($(this).is("#email")){
                if(this.value==""|| (this.value!=""&& !/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value))){
                    // var errmsg = "请输入正确的邮箱格式!";
                    // $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    $parent.find(".error").remove();
                }
            }
        })

实现的效果如下:

完整的例子

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>表单的选项验证</title>
    <script type="text/javascript" src="jquery-2.2.4.min.js"></script>
    <style>
        .int {
            width: 200px;
            padding: 12px;
            background-color: silver;
        }
        .container {
            width: 240px;
            align-content: center;
            display: block;
        }
        .high {
            color: red;
        }
    </style>
</head>
<body>
    <div align="center" class="container">
        <form method="post" action="">
            <fieldset>
                <legend>表单详情</legend>
                <div class="int">
                    <label for="username">用户名:</label>
                    <input type="text" id="username" class="required" />
                </div>
                <div class="int">
                    <label for="email">邮&nbsp;箱:</label>
                    <input type="email" id="email" class="required">
                </div>
                <div class="int">
                    <label for="persininfo">个人资料</label>
                    <textarea type="text" id="personinfo" ></textarea>
                </div>
                <div class="sub">
                    <input type="submit" value="提交" id="send">
                    <input type="reset" id="res">
                </div>
            </fieldset>
        </form>
    </div>
    <script>
        // 首先添加非空验证小红点
        $("form :input.required").each(function(){
            var $required = $("<strong class='high'>*</strong>");
            $(this).parent().append($required);
        });

        // 下面添加每个元素的特定的验证规则
        $("form :input").blur(function(){
            var $parent = $(this).parent();
            // 验证用户名
            if($(this).is("#username")){
                if(this.value=="" || this.value.length<6){
                    var errmsg = "请至少输入6位的用户名!";
                    $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    var rightmsg = "输入数据正确!";
                    $parent.append("<span>"+rightmsg+"</span>");
                }
            }

            // 验证邮箱
            if($(this).is("#email")){
                if(this.value==""|| (this.value!=""&& !/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value))){
                    var errmsg = "请输入正确的邮箱格式!";
                    $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    var rightmsg = "输入正确!";
                    // $parent.append("<span>"+rightmsg+"</span>");
                    $parent.append("<span>"+rightmsg+"</span>");
                }
            }
        });

        // 失去焦点之后删除之前的数据提示
        $("form :input.required").blur(function(){
            var $parent = $(this).parent();
            // $parent.find(".error").remove();
            if($(this).is("#username")){
                if(this.value=="" || this.value.length<6){
                    // var errmsg = "请至少输入6位的用户名!";
                    // $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    $parent.find(".error").remove();
                }
            }

            // 验证邮箱
            if($(this).is("#email")){
                if(this.value==""|| (this.value!=""&& !/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value))){
                    // var errmsg = "请输入正确的邮箱格式!";
                    // $parent.append("<span class='error'>"+errmsg+"</span>");
                }else{
                    $parent.find(".error").remove();
                }
            }
        })
    </script>
</body>
</html>

在实际的开发中,表单验证是非常的实用的,希望这段文字能帮到需要帮助的人。

使用 纯JQuery 进行 表单 验证的更多相关文章

  1. 纯CSS实现表单验证

    ladies and 乡亲们,表单验证你在做吗?客户端or服务器端,javascript or jquery,动手写 or 使用插件,今天我们来探索下使用纯css实现表单验证,借以学习css sele ...

  2. ASP.NET MVC Jquery Validate 表单验证的多种方式

    在我们日常开发过程中,前端的表单验证很重要,如果这块处理不当,会出现很多bug .但是如果处理的好,不仅bug会很少,用户体验也会得到很大的提升.在开发过程中我们可以不借助 JS 库,自己去手写 JS ...

  3. jQuery formValidator表单验证插件

    什么是jQuery formValidator? jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人 ...

  4. [转]ASP.NET MVC Jquery Validate 表单验证的多种方式介绍

    在我们日常开发过程中,前端的表单验证很重要,如果这块处理不当,会出现很多bug .但是如果处理的好,不仅bug会很少,用户体验也会得到很大的提升.在开发过程中我们可以不借助 JS 库,自己去手写 JS ...

  5. Jquery Validate 表单验证的多种方式

    ASP.NET MVC Jquery Validate 表单验证的多种方式 在我们日常开发过程中,前端的表单验证很重要,如果这块处理不当,会出现很多bug .但是如果处理的好,不仅bug会很少,用户体 ...

  6. 【锋利的jQuery】表单验证插件踩坑

    和前几篇博文提到的一样,由于版本原因,[锋利的jQuery]表单验证插件部分又出现照着敲不出效果的情况. 书中的使用方法: 1. 引入jquery源文件, 2. 引入表单验证插件js文件, 3. 在f ...

  7. jquery实现表单验证简单实例

    /* 描述:基于jquery的表单验证插件. */ (function ($) { $.fn.checkForm = function (options) { var root = this; //将 ...

  8. jQuery的表单验证

    jQuery的表单验证 直接上代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8" ...

  9. Jquery 实现表单验证,所有验证通过方可提交

    1. [代码]Jquery 实现表单验证,所有验证通过方可提交 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 ...

随机推荐

  1. Idea导入多个maven项目到同一目录下

    目标 简单导入多个maven项目进入同一个project(相当于eclipse的workspace) 过程 1.新建一个目录作为仿eclipse的workspace,这里起名为idea-workspa ...

  2. Scriplet的三种代码

    Jsp中注释分为显示注释和隐式注释, 显示注释 -- 可以通过查看源代码看到 <!-- 第一种注释 -->  隐式注释 --  源代码中看不到 <%--jsp注释---%> & ...

  3. BZOJ4711 小奇挖矿

    Description [题目背景] 小奇在喵星系使用了无限非概率驱动的采矿机,以至于在所有星球上都采出了一些矿石,现在它准备建一些矿石仓 库并把矿石运到各个仓库里. [问题描述] 喵星系有n个星球, ...

  4. 亲戚(relative)

    [题目背景] Y 家是世界上最大的家族,HJZ 是其中一员. 现在 Y 家人想要拍一张全家福,却发现这是一个十分复杂的问题. . . . . . [题目描述] Y 家一共有 n 人 其中每个人最多有一 ...

  5. bzoj 2437: [Noi2011]兔兔与蛋蛋

    Description Solution 考虑犯错误的条件:之前是处于必胜状态,该操作之后就变成了必败状态. 我们可以把这个过程看成两人对网格图进行黑白染色,变成了一个二分图模型,即当前位置向相邻不同 ...

  6. [Codeforces]853E - Lada Malina

    题目大意:给出平面上$n$个带权点$f_{i}$,再给出$k$个向量$v_{i}$,每次询问给出一个点$p$和一个值$t$,求能满足$f_{i}+\sum w_{j}v_{j}=p(-t<=w_ ...

  7. ●UVA 11021 tunnello

    题链: https://vjudge.net/problem/UVA-11021题解: 概率DP. 定义dp[i]表示初始1只麻球的情况下,第i天都死完的概率. (因为每只麻球互相独立,那么最后答案为 ...

  8. 【BZOJ3506】【Cqoi2014】排序机械臂

    传送门(因为BZOJ上没有题面...所以放的是luogu的) 题意:你需要维护一个序列,支持区间翻转与查询区间最小. 解题思路:由于区间最小实际上每一次就是对应的整个数列的第k小,因此可以直接预处理解 ...

  9. 【IOI1998】Picture(扫描线+线段树)

    问题来源:IOI1998 D2T1 题意:就是在一个平面内给出n个矩形,叫你计算将这些矩形合并以后,新图形的周长. 例如: 上图是原本的矩形们 ---------->合并后的图形 解题思路:拿一 ...

  10. hdu 5475(线段树)

    题意: 两个操作:① 当为1时 ,乘上后面的数 ② 当为2时,除以第x次乘的数 还说了2操作后面的n不会重复(就这明显看出线段树- -,然而并没有看出来,还是靠的队友) 1则对每个节点赋值,2则将相应 ...