开发者社区> bill.kang> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

jquery插件制作 -- 3.表单验证

简介:   今天的内容是关于表单验证插件的制作。表单验证控件实现的主要功能是,当表单提交的时候检查必填项是否正确填写,同时根据需要验证输入信息是否符合规范。   先下页面代码: DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.
+关注继续查看

  今天的内容是关于表单验证插件的制作。表单验证控件实现的主要功能是,当表单提交的时候检查必填项是否正确填写,同时根据需要验证输入信息是否符合规范。

  先下页面代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script type="text/javascript" src="Scripts/jquery-1.8.0.min.js"></script>
    <script type="text/javascript" src="Scripts/jquery.formCheck.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $('.formToCheck').formCheck();
        });
    </script>
    <style type="text/css">
        form
        {
            width: 300px;
        }
        label
        {
            position: absolute;
        }
        input:not(.submit), textarea
        {
            margin-left: 100px;
            width: 200px;
        }
        .submit
        {
            margin-left: 100px;
        }
        .error
        {
            border:1px solid red;
        }
    </style>
</head>
<body>
    <form class="formToCheck" id="formToCheck" method="get" action="#">
    <fieldset>
        <legend>a simple form</legend>
        <p>
            <label for="fname">
                * first name</label>
            <input id="fname" class="required" name="fname"  />
        </p>
        <p>
            <label for="lname">
                last name</label>
            <input id="lname" name="lname" />
        </p>
        <p>
            <label for="email">
                * email</label>
            <input id="email" name="email" class="required email" />
        </p>
        <p>
            <label for="comment">
                * comment</label>
            <input id="comment" name="comment" class="required" />
        </p>
        <p>
            <label for="email">
                * email</label>
            <input id="submit" type="submit" class="submit" value="submit" />
        </p>
    </fieldset>
    </form>
</body>
</html>

 

  我们定义了一个form,定义了几个输入框,请注意class属性,有的是class="required",说明该项是必填项;class="required email"说明该项是必填项,并且需要符合email格式。没有定义class的输入框不做验证。下面来看插件代码:

(function ($) {
    $.fn.formCheck = function (options) {
        var defaults = {
            errorClass: 'error'
        };
        var options = $.extend(defaults, options);

        return this.each(function () {
            var form = $(this);
            //如果不是from表单,直接返回不做任何操作
            if (!form.is('form')) {
                return;
            }
            //只有当form表单提交的时候,我们才做验证
            form.submit(function () {
                var errorFlag = false;

                //获取表单里面所有的input控件,逐一进行处理
                $(':input', this).each(function (index, item) {
                    //获取当前对象
                    var element = $(item);
                    //移除样式
                    element.removeClass(options.errorClass);

                    //必填项验证,value值不能为空
                    if (element.hasClass('required') && element.val().length == 0) {
                        errorFlag = true;
                        element.addClass(options.errorClass);
                    }
                    //数字验证
                    if (element.hasClass('number') && element.val().length > 0 && !/^\d+$/.test(element.val())) {
                        errorFlag = true;
                        element.addClass(options.errorClass);
                    }
                    //email验证
                    if (element.hasClass('email') && element.val().length > 0 
                && !/^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/.test(element.val())) { errorFlag = true; element.addClass(options.errorClass); } //验证数字长度 var num = this.className.match(/min(\d+)/i); if (num && element.val().length < num[1]) { errorFlag = true; element.addClass(options.errorClass); } }); return !errorFlag; }); }); }; })(jQuery);

 

  demo下载地址:jQuery.plugin.formcheck.zip

  今天的课程就到此为止了。

adpics.aspx?source=kbh1983&sourcesuninfo

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Jquery表单验证
用JQuery实现添加用户(用户注册登录同理)表单验证功能
0 0
jquery 表单验证
引用:http://blog.sina.com.cn/s/blog_608475eb0100h3h1.html 官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation 一导入js库 二、默认校验规则 (1)required:true               必输字段(2)remote:"check.
596 0
jQuery Label Better – 友好的表单输入框提示插件
  jQuery Label Better 帮助你标记您的表单输入域,带有美丽的动画效果而且不占用空间。这个插件的独特之处在于所有你需要做的就是添加一个占位符文本,只有当用户需要它的时候才显示标签。 您可能感兴趣的相关文章 推荐35款精致的 CSS3 和 HTML5 网页模板 精选12款...
565 0
12 个必要的 jQuery 表单插件
Web表单是网站中很常见的Web组件,你用它来收集数据,用户的详细信息等。然而,现有的表单限制很多,功能比较简单,尽管有 HTML5 ,不幸的是,并非所有浏览器都支持它,所以现在我们可以使用一些非常强大的jQuery或JavaScript来加强现有的表单元素的功能。
482 0
10 个基于jQuery的表单增强脚本和插件
以下10个基于jQuery的脚本和插件可以有效地提高表单的可访问性和功能性,本文中的一些源码和演示也许能帮助你优化当前的表单,使访问者获得良好的用户体验。 1. Form Hints 1.0 使用这个插件,你可以为网站中的的任何一个表单控件添加描述文字,可以通过title属性来添加。
302 0
jquery插件 - 表单插件
Jquery Form Plugin是jquery最重要的插件之一,它利用AJAX技术在不引起页面刷新的情况下POST表单。主要有两个方法:ajaxform和ajaxsubmit。它会自动收集表单元素内容,决定如何管理提交进程。
850 0
+关注
bill.kang
从事软件研发十余年,入行前端开发六年有余,对前端工程化有一定认识。 现就职于客如云科技有限公司,任前端技术经理一职。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
23-Vue.js在前端...1506518547.pdf
立即下载
零基础CSS入门教程
立即下载
低代码开发师(初级)实战教程
立即下载