zoukankan      html  css  js  c++  java
  • 表单验证

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
    <meta charset="UTF-8">
    <title>表单验证.html</title>
    <style>
    label{display:inline-block;65px;text-align: right;}
    .btn{margin-left: 130px;}
    .error{color:red;}
    .ok{color:green;}
    </style>
    <script src="jquery-1.7.2.min.js"></script>
    <script>
    $(function(){
    $("#username,#password").blur(function(){//当焦点不在用户名和密码框的时候

    if($(this).parent().find("span").length>0){ //如果里面已经追加有span了,就讲它清空掉
    $(this).parent().find("span").remove();
    }
    var val=$(this).val(); //获取当前输入框的值
    var reg=/^w{6,20}$/; //创建正则,首尾匹配只能输入6到20位的数字或者字母
    if(!reg.test(val)){ //如果匹配的结果为false,即与创建的正则不匹配,就
    $(this).parent().append('<span class="error">error</span>'); 在后面追加一个error,否则就追加一个ok
    }else{
    $(this).parent().append('<span class="ok">ok</span>');
    }
    });

    $("#userform").submit(function(){ //当提交表单的时候触发被选元素的blur事件
    $("#username").triggerHandler("blur");
    $("#password").triggerHandler("blur");
    if($("#userform").find(".error").length>0){//如果表单中已经有一个error,就不提交,否则,就提交
    return false;
    }
    });
    });
    </script>
    </head>
    <body>
    <form action="http://baidu.com" id="userform">
    <p><label for="username">用户名:</label><input type="text" name="username" id="username"></p>
    <p><label for="password">密 码:</label><input type="password" name="password" id="password"></p>
    <p><input type="submit" value="提交" class="btn"></p>
    </form>
    </body>
    </html>
    补充:
    triggerHandler() 方法触发被选元素上指定的事件。
    该方法与 trigger() 方法类似,不同的是 trigger() 也触发事件的默认行为(比如表单提交)。
    与 trigger() 方法相比的不同之处:
    1、它不会引起事件(比如表单提交)的默认行为
    2、.trigger() 会操作 jQuery 对象匹配的所有元素,而 .triggerHandler() 只影响第一个匹配元素。
    3、由 .triggerHandler() 创建的事件不会在 DOM 树中冒泡;如果目标元素不直接处理它们,则不会发生任何事情。
    该方法的返回的是事件处理函数的返回值,而不是具有可链性的 jQuery 对象。此外,如果没有处理程序被触发,则这个方法返回 undefined。

  • 相关阅读:
    iframe高度自适应方法
    mysql left join对于索引不生效的问题
    禁止百度转码和百度快照缓存的META声明
    使用graphviz绘制流程图
    安装php扩展sphinx-1.2.0.tgz和libsphinxclient0.9.9
    5种主要的编程风格和它们使用的抽象
    Nodejs调用Aras Innovator服务,处理AML并返回AML
    使用Rancher管理Docker
    docker容器间通信
    使用Portainer管理Docker
  • 原文地址:https://www.cnblogs.com/annie211/p/6009226.html
Copyright © 2011-2022 走看看