Java项目实战第2天:表单前端校验

今天是刘小爱自学Java的第101天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

image

一般来说绝大多数网站都会有用户注册、用户登录这些基本的功能。

那么用户注册具体是如何实现的呢?

这两天就主要学习注册的业务逻辑是如何写出来的。

先做一个简单的业务分析:

注册是用户在填写自己的相关信息,所以其本质上是在数据库中添加数据。

浏览器提交请求访问服务器,服务器去数据库查询数据判断用户注册是否成功:

  • 成功:发送邮件并跳转对应页面,同时将用户提交的数据添加到数据库中。

  • 失败:比如说用户名已经存在,需要提示用户注册失败的原因。

画个小图做一个说明:

image

以上就是一个基本的注册业务逻辑。

当然该方法是从后台检验用户提交的数据是否正确,事实上在前端中也能先进行校验。

一、表单前端校验

前端校验能起到优先判断的作用,阻止了很多不必要的请求,比如说:

  • 用户名为空的时候,不能直接提交。

  • 邮箱是有格式的,不能乱填。

  • 手机号也有对应的格式,不能乱填。

如果用户填写的数据不满足对应的格式,无法提交请求,这样也能节省更多资源。

所以前后端各自分工明确:

  • 前端校验数据的完整性与合法性。

  • 后台校验数据的唯一性。

而如何进行前端校验呢?

使用jQuery表单校验工具validate即可:

image

①表单校验工具validate

引入 jquery.validate.js 之后,就可以使用该工具了。

registerForm是我项目中注册表单对应的id,通过id选择器可以选择注册表单,从而进一步校验。

②表单校验规则

rules即可以定义表单的校验规则。

  • username和email:对应了表单中的属性。

  • required:表示该属性对应的值不能为空。

  • email:表示邮箱对应的校验规则。

当然表单中的属性不止这两个,都需要校验。

我只是以这两个作为例子,不然属性太多,截图放不下,代码编写其实都是大同小异的。

③自定义报错信息

如果不自定义信息,错误信息是英文的,所以使用messages将错误信息设置成对应的中文字符串。

二、自定义校验规则

上述都是插件validate自带的校验规则,但是有些需要我们自定义。

比如说电话号码各个国家不一样,所以就需要自定义一个校验规则。

代码的编写都是差不多的,只不过加入了自定义的判断逻辑。

image

①自定义校验规则

我这边自定义的名称为phoneFmt,后面的参数为:true。

也就是说需要满足对应的校验要求,不然会出现错误提示信息。

②addMethod方法

使用该方法可以实现具体的校验逻辑,其有三个参数:

  • 校验规则名:也就是和①中的名称相对应。

  • 一个函数:也就是具体校验逻辑。

  • “手机号不合法”:也就是错误信息。

其中第二个参数,函数也有三个参数:

  • value:被校验的文本框的value值,这里指用户在电话栏里填入的数据。

  • element:被校验规则的文本框,这里是指整个telephone标签。

  • params:接受校验规则参数,这里是指①中后面的true。

③具体校验逻辑

new RegExp()表示创建一个对应的正则匹配规则。

关于正则表达式,想要完全把它记下来是很难的,所以很多时候需要借助于网络查询。

不过就算网络上的资源有很多,但是也要能看得懂,查询资料如下:

image

该资料创建正则表达式的方式,是使用两个斜杠将具体的匹配规则包裹起来:/ /

而我一开始使用的是new RegExp(),这两种方式都可以。

而"^1[34578]\d{9}$"这个表示的是什么意思呢?

  • 1:表示的是第1个数字必须为1。

  • [34578]:表示的是第2个数字必须得是34578中的一个。

  • d{9}$:表示的是还有9个数字,可以是任意数。

加起来一共11个数字,也正是我们国家手机号码的长度。

以上就是自定义校验规则的代码编写。

事实上多个页面都需要该规则,比如注册页面需要,登录页面也需要。

既然如此,将其封装到一个js文件中,哪个页面需要使用该校验规则,引入js文件就好了:

image

上述便是对自定义校验规则的封装,有点类似于Java代码中工具类的封装。

最后

因为遇到了一个bug未解决,导致这两天学习效率有点低,希望自己能早日调整过来。

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351