学习LayUI时自研的表单参数校验框架案例分析


Posted in Javascript onJuly 29, 2019

开发背景&痛点 :

每次写前端的表单的时候需要对表单里用户填写的内容进行校验,减少服务器压力,提前对已知错误对用户提示。每次会要写很多的if else等等对输入框中的内容进行判断,并对为空、格式不正确等情况作出对应提示。

需要写大量重复的if else语句,实在太麻烦,所以自己写了这个框架用于前端参数的校验。

本框架基于LayUI框架

对于三种开发者情况:

1、完全不会LayUI也没有任何关系 在html头部中添加如下代码就OK了

<script src="https://www.layuicdn.com/layui/layui.js"></script>
<link rel="stylesheet" href="https://www.layuicdn.com/layui/css/layui.css">
<script>
  var layer=layui.layer;
  var form=layui.form;
  layui.use(['layer','form'],function () {})
</script>

2、使用了LayUI框架进行开发则无需做改变

3、使用了其他前端UI框架将源码中下面语句转换成你的UI框架的提示框即可。

layer.tips(tipname+'不合法('+tiplegal+')',chooser,{
        tips: [2, '#FF0000']
      })

使用本参数校验框架需要引入一个js文件(可以下载到本地使用)

在Html头部插入如下代码引入JS

<script src="https://mywarehouse.oss-cn-shenzhen.aliyuncs.com/ParaCheck.js"></script>

使用案例

HTML:

学习LayUI时自研的表单参数校验框架案例分析

本注册页面对应JS文件

学习LayUI时自研的表单参数校验框架案例分析

使用效果

直接点击注册

学习LayUI时自研的表单参数校验框架案例分析

输入1后点击注册

学习LayUI时自研的表单参数校验框架案例分析

API:

核心接口:

1:paraCheck(chooser,name,regex,legal)//单个输入框检查函数,传入的三个参数为,选择器(#id或者.class)、输入框名称(中文意义,比如手机号码)、正则匹配式(比如验证码输入框对应的正则表达式为/^[0-9]{6}$/)

2:multiParaCheck(choosers,names,regexs,legals)//批量校验函数

返回值:

1:true  全部通过校验

2:false 出现未通过校验的输入框,实时进行如上图对用户进行提示

备注:第一个参数必填,第二、三、四个参数选填,建议都传入,用户体验感好,如果您不想麻烦,只检测是否是空的,那只需要传入第一个参数。

图中注册界面脚本代码:

(注册按钮onclick="register()")

function register() {
  var choosers=['#phone','#content','#password','#name','#stuId','#gender','#grade','#major','#classNumber'];
  var names=['手机号码','短信验证码','密码','姓名','学号','性别','年级','专业','班级'];
  var regexs=[/^((13[0-9])|(14[5,7,9])|(15([0-3]|[5-9]))|(166)|(17[0,1,3,5,6,7,8])|(18[0-9])|(19[8|9]))\d{8}$/,/^[0-9]{6}$/,/^[0-9a-zA-Z]{8-20}$/,/^[\u4e00-\u9fa5]{2,5}$/,/^2[0-9]{11}$/,/^[男女]$/,/^20[0-9]{2}$/,/^[\u4e00-\u9fa5]{2,10}$/,/^[0-9]{1,2}$/];
  var legals=['11位数字','6位数字','8-20位数字、字母','2-5位中文','12位数字','男|女','4位数字','2-10位中文','1-2位数字'];
  if(multiParaCheck(choosers,names,regexs,legals))
  {
    if ($('#password').val()!=$('#repeatPassword').val())
    {
      layer.tips('两次密码输入不一致','#repeatPassword',{
        tips: [2, '#FF0000']
      });
      return;
    }
    var formData=new FormData();
    for(var i=0;i<choosers.length;i++)
      formData.append(choosers[i].replace('#',''),$(choosers[i]).val());
    $.ajax({
      type: "get",
      url: "/fpa/member/login",
      xhrFields: {withCredentials: true},
      data: formData,
      dataType: "text",
      success: function (data) {
        layer.alert(data);
        if (data.indexOf('成功') > -1)
          window.href.open('/login.html');
      }
    });
  }
}

总结

以上所述是小编给大家介绍的学习LayUI时自研的表单参数校验框架案例分析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
js 自定义个性下拉选择框示例
Aug 20 Javascript
js中settimeout方法加参数
Feb 28 Javascript
深入分析Javascript跨域问题
Apr 17 Javascript
简介JavaScript中的setDate()方法的使用
Jun 11 Javascript
JavaScript中的Math.SQRT1_2属性使用简介
Jun 14 Javascript
JS中使用apply、bind实现为函数或者类传入动态个数的参数
Apr 26 Javascript
jquery解析XML及获取XML节点名称的实现代码
May 18 Javascript
Vue.js中用v-bind绑定class的注意事项
Dec 13 Javascript
微信小程序利用Canvas绘制图片和竖排文字详解
Jun 25 Javascript
安装多版本Vue-CLI的实现方法
Mar 24 Javascript
vue实现整屏滚动切换
Jun 29 Javascript
解决vue项目运行npm run serve报错的问题
Oct 26 Javascript
jquery.pager.js分页实现详解
Jul 29 #jQuery
javascript面向对象创建对象的方式小结
Jul 29 #Javascript
jquery.pager.js实现分页效果
Jul 29 #jQuery
vue-router跳转时打开新页面的两种方法
Jul 29 #Javascript
JS实现移动端点击按钮复制文本内容
Jul 28 #Javascript
微信小程序文字显示换行问题
Jul 28 #Javascript
vue router 跳转时打开新页面的示例方法
Jul 28 #Javascript
You might like
2.PHP入门
2006/10/09 PHP
PHP读取txt文件的内容并赋值给数组的代码
2011/11/03 PHP
PHP遍历目录文件的常用方法小结
2017/02/03 PHP
LazyForm jQuery plugin 定制您的CheckBox Radio和Select
2009/10/24 Javascript
Jquery在IE7下无法使用 $.ajax解决方法
2009/11/11 Javascript
jQuery动态添加的元素绑定事件处理函数代码
2011/08/02 Javascript
js获取对象为null的解决方法
2013/11/21 Javascript
jQuery中height()方法用法实例
2014/12/24 Javascript
jQuery EasyUI中DataGird动态生成列的方法
2016/04/05 Javascript
jQuery实现摸拟alert提示框
2016/05/22 Javascript
Bootstrap文件上传组件之bootstrap fileinput
2016/11/25 Javascript
vue-resourse将json数据输出实例
2017/03/08 Javascript
JavaScript数据结构之链表的实现
2017/03/19 Javascript
JS之if语句对接事件动作逻辑(详解)
2017/06/28 Javascript
vue2.X组件学习心得(新手必看篇)
2017/07/05 Javascript
Node 自动化部署的方法
2017/10/17 Javascript
vue引入ueditor及node后台配置详解
2018/01/03 Javascript
JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解【矩形情况】
2018/12/13 Javascript
vue2 中二级路由高亮问题及配置方法
2019/06/10 Javascript
微信小程序页面间跳转传参方式总结
2019/06/13 Javascript
利用js-cookie实现前端设置缓存数据定时失效
2019/06/18 Javascript
[45:52]完美世界DOTA2联赛PWL S3 Forest vs INK ICE 第二场 12.09
2020/12/12 DOTA
python判断数字是否是超级素数幂
2018/09/27 Python
Django forms组件的使用教程
2018/10/08 Python
python实现windows倒计时锁屏功能
2019/07/30 Python
使用coverage统计python web项目代码覆盖率的方法详解
2019/08/05 Python
python单例设计模式实现解析
2020/01/07 Python
Python实现密钥密码(加解密)实例详解
2020/04/26 Python
香港礼品网站:GiftU eshop
2017/09/01 全球购物
实现向右循环移位
2014/07/31 面试题
经典的班主任推荐信
2013/10/28 职场文书
技术总监的工作职责
2013/11/13 职场文书
奉献演讲稿范文
2014/05/21 职场文书
《半截蜡烛》教学反思
2016/02/19 职场文书
python requests模块的使用示例
2021/04/07 Python
golang goroutine顺序输出方式
2021/04/29 Golang