Java项目实战第2天:表单校验 表单校验规则
yuyutoo 2024-11-14 19:53 1 浏览 0 评论
今天是刘小爱自学Java的第101天。
感谢你的观看,谢谢你。
话不多说,开始今天的学习:
一般来说绝大多数网站都会有用户注册、用户登录这些基本的功能。
那么用户注册具体是如何实现的呢?
这两天就主要学习注册的业务逻辑是如何写出来的。
先做一个简单的业务分析:
注册是用户在填写自己的相关信息,所以其本质上是在数据库中添加数据。
浏览器提交请求访问服务器,服务器去数据库查询数据判断用户注册是否成功:
- 成功:发送邮件并跳转对应页面,同时将用户提交的数据添加到数据库中。
- 失败:比如说用户名已经存在,需要提示用户注册失败的原因。
画个小图做一个说明:
以上就是一个基本的注册业务逻辑。
当然该方法是从后台检验用户提交的数据是否正确,事实上在前端中也能先进行校验。
一、表单前端校验
前端校验能起到优先判断的作用,阻止了很多不必要的请求,比如说:
- 用户名为空的时候,不能直接提交。
- 邮箱是有格式的,不能乱填。
- 手机号也有对应的格式,不能乱填。
如果用户填写的数据不满足对应的格式,无法提交请求,这样也能节省更多资源。
所以前后端各自分工明确:
- 前端校验数据的完整性与合法性。
- 后台校验数据的唯一性。
而如何进行前端校验呢?
使用jQuery表单校验工具validate即可:
①表单校验工具validate
引入 jquery.validate.js 之后,就可以使用该工具了。
registerForm是我项目中注册表单对应的id,通过id选择器可以选择注册表单,从而进一步校验。
②表单校验规则
rules即可以定义表单的校验规则。
- username和email:对应了表单中的属性。
- required:表示该属性对应的值不能为空。
- email:表示邮箱对应的校验规则。
当然表单中的属性不止这两个,都需要校验。
我只是以这两个作为例子,不然属性太多,截图放不下,代码编写其实都是大同小异的。
③自定义报错信息
如果不自定义信息,错误信息是英文的,所以使用messages将错误信息设置成对应的中文字符串。
二、自定义校验规则
上述都是插件validate自带的校验规则,但是有些需要我们自定义。
比如说电话号码各个国家不一样,所以就需要自定义一个校验规则。
代码的编写都是差不多的,只不过加入了自定义的判断逻辑。
①自定义校验规则
我这边自定义的名称为phoneFmt,后面的参数为:true。
也就是说需要满足对应的校验要求,不然会出现错误提示信息。
②addMethod方法
使用该方法可以实现具体的校验逻辑,其有三个参数:
- 校验规则名:也就是和①中的名称相对应。
- 一个函数:也就是具体校验逻辑。
- “手机号不合法”:也就是错误信息。
其中第二个参数,函数也有三个参数:
- value:被校验的文本框的value值,这里指用户在电话栏里填入的数据。
- element:被校验规则的文本框,这里是指整个telephone标签。
- params:接受校验规则参数,这里是指①中后面的true。
③具体校验逻辑
new RegExp()表示创建一个对应的正则匹配规则。
关于正则表达式,想要完全把它记下来是很难的,所以很多时候需要借助于网络查询。
不过就算网络上的资源有很多,但是也要能看得懂,查询资料如下:
该资料创建正则表达式的方式,是使用两个斜杠将具体的匹配规则包裹起来:/ /
而我一开始使用的是new RegExp(),这两种方式都可以。
而"^1[34578]\d{9}#34;这个表示的是什么意思呢?
- 1:表示的是第1个数字必须为1。
- [34578]:表示的是第2个数字必须得是34578中的一个。
- d{9}$:表示的是还有9个数字,可以是任意数。
加起来一共11个数字,也正是我们国家手机号码的长度。
以上就是自定义校验规则的代码编写。
事实上多个页面都需要该规则,比如注册页面需要,登录页面也需要。
既然如此,将其封装到一个js文件中,哪个页面需要使用该校验规则,引入js文件就好了:
上述便是对自定义校验规则的封装,有点类似于Java代码中工具类的封装。
最后
因为遇到了一个bug未解决,导致这两天学习效率有点低,希望自己能早日调整过来。
谢谢你的观看。
如果可以的话,麻烦帮忙点个赞,谢谢你。
相关推荐
- jQuery VS AngularJS 你更钟爱哪个?
-
在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...
- Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
-
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...
- 如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例
-
要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...
- 编程技巧:Jquery实时验证,指定长度的「负小数」
-
为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...
- 一篇文章带你用jquery mobile设计颜色拾取器
-
【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...
- 编程技巧:Jquery实时验证,指定长度的「正小数」
-
为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...
- jquery.validate检查数组全部验证
-
问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...
- Vue进阶(幺叁肆):npm查看包版本信息
-
第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...
- layui中使用lay-verify进行条件校验
-
一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...
- jQuery是什么?如何使用? jquery是什么功能组件
-
jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...
- django框架的表单form的理解和用法-9
-
表单呈现...
- jquery对上传文件的检测判断 jquery实现文件上传
-
总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...
- Nodejs之MEAN栈开发(四)-- form验证及图片上传
-
这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...
- 大数据开发基础之JAVA jquery 大数据java实战
-
上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...
- 推荐四个开源的jQuery可视化表单设计器
-
jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)