jQuery 正则表达式 验证表单

简介:

jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地、无侵入地升级HTML表单以支持Ajax。jQuery
Form有两个核心方法 – ajaxForm() 和 ajaxSubmit(),
它们集合了从控制表单元素到决定如何管理提交进程的功能。另外,插件还包括其他的一些方法:
formToArray()、formSerialize()、fieldSerialize()、fieldValue()、clearForm()、clearFields()
和 resetForm()等。

什么是正则表达式以及作用:

正则表达式,又称规则表达式,(Regular
Expression,在代码中常简写为regex、regexp或RE),是一种文本模式,包括普通字符(例如,a 到 z
之间的字母)和特殊字符(称为"元字符"),是计算机科学的一个概念。

正则表达式中的括号()主要有两个作用:分组和捕获。

  1. 分组:在正则表达式中,括号可以用来将一些字符组合在一起,形成一个分组。这通常用于确定优先级、重复次数或特殊的匹配规则。例如,(ab)可以将字符a和b组合在一起作为一个整体进行匹配。
  2. 捕获:当正则表达式中的括号内匹配到特定的文本时,可以将这些文本保存下来,以便后续使用。捕获的内容可以用于替换操作或者在其他正则表达式中进行引用。例如,在替换操作中,可以使用\1来引用第一个捕获的内容。

●文本框内容的验证:

1、实现思路

2、使用 String 对象的 length 属性验证密码的长度

3、验证两次输入密码是否一致

4、使用 length 属性获取文本长度,然后使用 for 循环和 substring ( ) 方法依次截断单个字符,最后判断每个字符是否是数字

标签描述
form定义供用户输入的表单
input定义输入域
textarea定义文本域 (一个多行的输入控件)
label定义了 input 元素的标签,一般为输入标题
fieldset定义了一组相关的表单元素,并使用外框包含起来
legend定义了 fieldset 元素的标题
select定义了下拉选项列表
optgroup定义选项组
option定义下拉列表中的选项
button定义一个点击按钮

代码演示示例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<style>

  .over { font-size: large; font-style: italic; }
  .out { font-size: small; }
</style>
<body>

<div id="display">demo</div>
<div id="test">

</div>
<br><br>
<form id="theForm">
  输入字符
  <div>
    <input type="text" id="username" onblur="isString(this.value)">
  </div>
  输入正确的数字
  <div>
    <input type="text" id="password" onblur="isInteger(this.value)">
  </div>
  输入正确的电话
  <div>
    <input type="text" id="telephone" onblur="isTelephone(this.value)">
  </div>
  确移动电话
  <div>
    <input type="text" id="mobile" onblur="isMobile(this.value)">
  </div>
  邮箱地址
  <div>
    <input type="text" id="email" onblur="isEmail(this.value)">
  </div>
  inernet地址
  <div>
    <input type="text" id="uri" onblur="isUri(this.value)">
  </div>
  <div>
    <input type="button" value="Validata" onclick="return validata();">
  </div></form>
<script src="../jQuery/jquery-1.12.4.js"></script>
<script>
  function validata() {
    if ($("#username").val() == "") {
      alert("请输入名字");
      return false;
    }
    if ($("#password").val() == "") {
      alert("请输入密码");
      return false;
    }
    if ($("#telephone").val() == "") {
      alert("请输入电话号码");
    }
    if ($("#email").val() == "") {
      $("#email").val("shuangping@163.com");
    }
  }
  function isInteger(obj) {
    reg = /^[-+]?\d+$/;
    if (!reg.test(obj)) {
      $("#test").html("<b>Please input correct figures</b>");
    } else {
      $("#test").html("");
    }
  }
  function isEmail(obj) {
    reg = /^\w{3,}@\w+(\.\w+)+$/;
    if (!reg.test(obj)) {
      $("#test").html("<b>请输入正确的邮箱地址</b>");
    } else {
      $("#test").html("");
    }
  }
  function isString(obj) {
    reg = /^[a-z,A-Z]+$/;
    if (!reg.test(obj)) {
      $("#test").html("<b>只能输入字符</b>");
    } else {
      $("#test").html("");
    }
  }
  function isTelephone(obj) {
    reg = /^(\d{3,4}\-)?[1-9]\d{6,7}$/;
    if (!reg.test(obj)) {
      $("#test").html("<b>请输入正确的电话号码!</b>");
    } else {
      $("#test").html("");
    }
  }
  function isMobile(obj) {
    reg = /^(\+\d{2,3}\-)?\d{11}$/;
    if (!reg.test(obj)) {
      $("#test").html("请输入正确移动电话");
    } else {
      $("#test").html("");
    }
  }
  function isUri(obj) {
    reg = /^http:\/\/[a-zA-Z0-9]+\.[a-zA-Z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/;
    if (!reg.test(obj)) {
      $("#test").html($("#uri").val() + "请输入正确的inernet地址");
    } else {
      $("#test").html("");
    }
  }
  //document加载完毕执行
  $(document).ready(function() {
    // do something here
    //隔行换色功能
    $("p").each(function(i) {
      this.style.color = ['red', 'green', 'blue', 'black'][i % 2]
    });
    //eq(2)获取$("p")集合的第3个元素
    $("p").eq(2).click(function() {
      $("#display").css("color", "blue")
    });
    //所有test中的p都附加了样式"over"。
    $("#test>p").addClass("over");
    //test中的最后一个p附加了样式"out"。
    $("#test p:last").addClass("out");
    //选择同级元素还没看懂
    //$('#faq').find('dd').hide().end().find('dt').click(function()
    //选择父级元素
    $("a").hover(function() {
        $(this).parents("p").addClass("out")
      },
      function() {
        $(this).parents("p").removeClass("out")
      })
    //hover鼠标悬停效果,toggle每次点击时切换要调用的函数 ,
    //trigger(eventtype): 在每一个匹配的元素上触发某类事件,
    //bind(eventtype,fn),unbind(eventtype): 事件的绑定与反绑定从每一个匹配的元素中(添加)删除绑定的事件。
    //方法的连写
    $("#display").hover(function() {
        $(this).addClass("over");
      },
      function() {
        $(this).removeClass("over");
      }).click(function() {
      alert($("#display").text())
    });

  });

</script>
</body>
</html>
  • 11
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个基于jQuery和HTML的注册页面示例代码,其中包括电子邮件的正则表达式验证: HTML代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>注册页面</title> <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script> <script src="register.js"></script> </head> <body> <h1>注册页面</h1> <form id="registerForm"> <div> <label for="username">用户名:</label> <input type="text" id="username" name="username" required> </div> <div> <label for="password">密码:</label> <input type="password" id="password" name="password" required> </div> <div> <label for="age">年龄:</label> <input type="number" id="age" name="age" min="1" max="150" required> </div> <div> <label for="email">电子邮件:</label> <input type="email" id="email" name="email" required> </div> <div> <input type="submit" value="注册"> </div> </form> </body> </html> ``` jQuery代码(存储在register.js文件中): ```javascript $(document).ready(function() { // 电子邮件的正则表达式 var emailRegex = /^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}$/; // 注册表单提交事件 $('#registerForm').submit(function(event) { // 阻止表单默认提交行为 event.preventDefault(); // 获取表单数据 var username = $('#username').val(); var password = $('#password').val(); var age = $('#age').val(); var email = $('#email').val(); // 对电子邮件进行正则表达式验证 if (!emailRegex.test(email)) { alert('请输入有效的电子邮件地址!'); return; } // TODO:将表单数据提交到后台进行注册 alert('注册成功!'); }); }); ``` 在这个示例中,我们使用了HTML5的表单验证jQuery表单提交事件处理程序。我们还使用了一个正则表达式验证电子邮件地址,确保它符合有效的格式。如果电子邮件地址无效,我们会弹出一个警告框。否则,表单数据将被提交到后端进行处理。你需要确保在后端进行适当的输入验证和安全性检查。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值