JQuery插件,轻量级表单模型验证
附上源码和Demo段
- var validataForm = (function(model) {
- model.Key = "[data-required='true']";
- model.ElementList = new Array();
- model.FunctionDictionary = new Dictionary();
- model.ToastrCustom = function (msg) {
- alert(msg);
- }
- model.AddElement = function (name) {
- model.ElementList.push(name);
- };
- model.AddFunction = function (name, func) {
- model.FunctionDictionary.add(name, func);
- };
- model.Validata = function (formName) {
- for (var i = 0; i < model.ElementList.length; i++) {
- var thisObj = model.ElementList[i];
- var str = formName + " " + thisObj + model.Key;
- var elements = $(str);
- for (var j = 0; j < elements.length; j++) {
- var element = elements.eq(j);
- var value = element.val();
- var elementType = element.data().type;
- var func = model.FunctionDictionary.find(elementType);
- if (func) {
- var result = func(value, element);
- if (result.status) {
- var errorInfo = result.message;
- model.ToastrCustom(errorInfo);
- return;
- }
- }
- }
- }
- };
- model.ElementList.push("input");
- model.ElementList.push("select");
- model.FunctionDictionary.add("required", function (value, element) {
- var name = element.data().name;
- return {
- status: (value === ""),
- message: (value === "" && name + "不能为空")
- };
- });
- return model;
- })(window.validataForm || {});
调用处
- <form id="ValidataForm">
- <input data-required="true" data-name="名称" data-type="required" value="">
- <input data-required="true" data-name="昵称" data-type="hello">
- <button id="Send">提交</button>
- </form>
- <script src="~/js/plugs/jquery-3.3.1.js"></script>
- <script src="~/js/Dictionary.js"></script>
- <script src="~/js/ValidataForm.js"></script>
- <script type="text/javascript">
- $("#Send").click(function () {
- validataForm.Validata("#ValidataForm");
- });
- </script>
Dictionary这个对象是抄一个博主的
代码附上,内置链接
- /* https://www.cnblogs.com/baiyangyuanzi/p/6689554.html */
- /*字典 Dictionary类*/
- function Dictionary() {
- this.add = add;
- this.datastore = new Array();
- this.find = find;
- this.remove = remove;
- this.count = count;
- this.clear = clear;
- }
- function add(key, value) {
- this.datastore[key] = value;
- }
- function find(key) {
- return this.datastore[key];
- }
- function remove(key) {
- delete this.datastore[key];
- }
- function count() {
- /*var ss = Object.keys(this.datastore).length;
- console.log("ssss "+ss);
- return Object.keys(this.datastore).length;*/
- /**/
- var n = 0;
- for (var key in Object.keys(this.datastore)) {
- ++n;
- }
- return n;
- }
- function clear() {
- for (var key in this.datastore) {
- delete this.datastore[key];
- }
- }
萌新初试前端,有写得不好的地方,望各位前辈,多多指教
JQuery插件,轻量级表单模型验证的更多相关文章
- JQuery插件,轻量级表单模型验证(续 二)
好不容易,有心思,那就把没做完的JQuery轻量级表单验证做完吧 之前做到了空参数验证的,现在增加带参数的验证. 附上html <form id="ValidataForm" ...
- JQuery插件,轻量级表单模型验证(续 一)
之前的代码结构,不方便扩展多结构的模型验证 重新结构设计了一下验证模型核心 var validateForm = (function(model) { model.Key = "[data- ...
- 自己编写jQuery插件之表单验证
自己编写jQuery插件之表单验证 吐个嘈先:最近状态不咋滴,真是什么都不想干,不想上班,做什么都没动力,觉得没意思.不想这样,不想这样,快让这种情绪消失吧,忽忽.... 表单验证在项目中用的还是比较 ...
- Jquery插件easyUi表单验证提交
<form id="myForm" method="post"> <table align="center" style= ...
- MVC遇上bootstrap后的ajax表单模型验证
MVC遇上bootstrap后的ajax表单验证 使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jqueyr.validate的话只有使用他自己的样式了, ...
- jQuery插件 -- Form表单插件jquery.form.js<转>
jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地.无侵入地升级HTML表单以支持Ajax.jQuery Form有两个核心方法 -- ajaxForm() 和 ajaxSubmi ...
- (转)jQuery插件 -- Form表单插件jquery.form.js
beforeSubmit: validate function validate(formData, jqForm, options) { //在这里对表单进行验证,如果不符合规则,将返回false来 ...
- jQuery插件 -- Form表单插件jquery.form.js
http://blog.csdn.net/zzq58157383/article/details/7718956 http://my.oschina.net/i33/blog/77250
- 表单验证代码实例:jquery.validate.js表单验证插件
jquery.validate.js是JQuery旗下的一个验证插件,借助JQuery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法.使用前请先下载必要的JQuery插件:jq ...
随机推荐
- Redis的主从复制(基本入门)
描述 从主节点(主机)到从节点(从机)单向的数据复制 特性(主从复制是Redis高可用的基础) 数据冗余 故障恢复 负载均衡 读写分离(主节点有读写权限,从节点只有读的权限) 注:以下操作都是在cen ...
- ES6入门(二)
目录 ES6入门(二) es6之解构赋值 数组的解构赋值 对象的解构赋值 字符串的解构赋值 数值和布尔值的解构赋值 函数参数的解构赋值 圆括号问题 ES6入门(二) es6之解构赋值 数组的解构赋值 ...
- 006.Nginx访问控制
一 Nginx连接限制 1.1 HTTP协议的连接与请求 HTTP是建立在TCP, 一次HTTP请求需要先建立TCP三次握手(称为TCP连接),在连接的基础上再进行HTTP请求. HTTP请求建立在一 ...
- Java标识符/数据类型,规范等详解
Java标识符 类名/变量名/方法名都称之为标识符. Java 所有的组成部分都需要名字.类名.变量名以及方法名都被称为标识符. 关于 Java 标识符,有以下几点需要注意: 所有的标识符都应该以字母 ...
- LNMP安装composer install时出现Warning: putenv()
layout: post title: LNMP安装composer install时出现Warning: putenv() has been disabled for security reason ...
- DVWA学习记录 PartⅡ
Command Injection 1. 题目 Command Injection,即命令注入,是指通过提交恶意构造的参数破坏命令语句结构,从而达到执行恶意命令的目的. 2. Low a. 代码分析 ...
- scrapy shell 的使用
是什么?:是一个终端下的调试工具,用来调试scrapy 安装ipython :pip install ipython 启动: scrapy shell + 需要请求的url 进来之后,response ...
- Centos7:python 安装。yum安装软件提示 cannot find a valid baseurl for repobase7x86_64
方法一. 1.打开 vi /etc/sysconfig/network-scripts/ifcfg-enp4s0(每个机子都可能不一样,但格式会是“ifcfg-e...”).但内容包含: < ...
- java 面向对象(二十七):注解的使用
1. 注解的理解① jdk 5.0 新增的功能*② Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理.通过使用 Annotation, ...
- (五)学习了解OrchardCore笔记——灵魂中间件ModularTenantContainerMiddleware的第一行②模块的功能部分
在(三)的时候已经说到模块集合用ForEachAsync的扩展方法分配多个任务,把每个modules的ManifestInfo分析出来的功能加入ConcurrentDictionary.我们先看看这个 ...