ValidFrom验证控件

ValidForm是一款前端表单验证插件,通过将验证条件绑定在表单元素上,实现灵活的表单验证。它提供多种内置的datatype,如*n, *6-16, n, s等,同时支持自定义datatype和正则表达式。此外,它还包括nullmsg、sucmsg、errormsg等属性用于定制提示信息,以及ajaxurl进行实时后台验证。" 105796886,8388204,使用POI 3.9设置Excel单元格为数值类型,"['poi', 'excel', 'java']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介:

Validform的核心思想为将所有的验证条件以及验证的提示信息绑定在每个表单元素上,让验证该代码时对表单各个元素的值是否跟绑定的验证条件相符,这样就可以随便的添加或者去掉任意一表单元素而不必去修改验证代码,从而仅适用一行代码去完成整站的表单验证。

简单的使用方法

引用js

   <script type="text/javascript" src="~/lib/Validform/5.3.2/Validform.min.js"></script>

给需要的表单添加元素

 <input type="text" class="input-text" value="" placeholder="权限描述" id="user-name" name="Description" datatype="*2-16" nullmsg="权限描述不能为空">

初始化

 $("#form-admin-add").Validform

凡是需要验证格式的元素均需要绑定datatype属性,datatype可选值内置了10类,来指定不同的验证格式。如果还不能满足所需的验证需求,可以传入自定义datatype;

//绑定方法如下
<!--ajax实时验证用户名-->
<input type="text" value="" name="name" datatype="e" ajaxurl="valid.php?myparam1=value1&myparam2=value2" sucmsg="用户名验证通过!" nullmsg="请输入用户名!" errormsg="请用邮箱或手机号码注册!"  />
 
<!--密码-->
<input type="password" value="" name="userpassword" datatype="*6-15" errormsg="密码范围在6~15位之间!" />
<!--确认密码-->
<input type="password" value="" name="userpassword2" datatype="*" recheck="userpassword" errormsg="您两次输入的账号密码不一致!" />
 
<!--默认提示文字-->
<textarea tip="请在这里输入您的意见。" errormsg="很感谢您花费宝贵时间给我们提供反馈,请填写有效内容!"  datatype="s" altercss="gray" class="gray" name="msg" value="">请在这里输入您的意见。</textarea>
 
<!--使用swfupload插件-->
<input type="text" plugin="swfupload" class="inputxt" disabled="disabled" value="">
<input type="hidden" value="" pluginhidden="swfupload">
 
<!--使用passwordStrength插件-->
<input type="password" errormsg="密码至少6个字符,最多18个字符!" datatype="*6-18" plugin="passwordStrength" class="inputxt" name="password" value="">
<div class="passwordStrength" style="display:none;"><b>密码强度:</b> <span>弱</span><span>中</span><span class="last">强</span></div>

————————————————
版权声明:本文为优快云博主「JERSENLEIBOY」的原创文章
原文链接:https://blog.youkuaiyun.com/qq_31873539/article/details/83268049

.初始化参数说明 

$(".demoform").Validform({
	btnSubmit:"#btn_sub", //触发提交的元素
	btnReset:".btn_reset",//触发重置表单的元素
	tiptype:1, //弹出框提示默认为1,可选值为1,2,3和function函数
	ignoreHidden:false,//默认为false,布尔值类型,对hidden的表单元素将不做验证
	dragonfly:false,//默认为false,布尔值类型,值为空时不做验证
	tipSweep:true,//默认false,布尔值类型,各表单元素只会在表单提交时进行触发,表单元素在blur时不会进行触发
	label:".label",//在没有绑定nullmsg时查找要显示的提示文字,默认查找“.Validform_label”下的文字
	showAllError:false,//默认false,布尔值类型,提交表单时所有错误信息都会显示,一般验证不通过的对象时就会停止,不会进行下一表单的验证,只显示该元素的错误信息
	postonce:true,//默认false,指定是否开启二次提交防御,在数据成功提交后,表单将不能再继续提交。
	ajaxPost:true,//默认false,使用ajax方法进行表单提交方式,将会将数据POST到config方法或表单属性里的action属性设定的地址。
	datatype:{
		"*6-20": /^[^\s]{6,20}$/,
		"z2-4" : /^[\u4E00-\u9FA5\uf900-\ufa2d]{2,4}$/,
		"username":function(gets,obj,curform,regxp){
			//参数gets是获取到的表单元素值,obj为当前表单元素,curform为当前验证的表单,regxp为内置的一些正则表达式的引用;
			var reg1=/^[\w\.]{4,16}$/,
				reg2=/^[\u4E00-\u9FA5\uf900-\ufa2d]{2,8}$/;
 
			if(reg1.test(gets)){return true;}
			if(reg2.test(gets)){return true;}
			return false;
 
			//注意return可以返回true 或 false 或 字符串文字,true表示验证通过,返回字符串表示验证失败,字符串作为错误提示显示,返回false则用errmsg或默认的错误提示;
		},
		"phone":function(){
			// 5.0 版本之后,要实现二选一的验证效果,datatype 的名称 不 需要以 "option_" 开头;	
		}
	},
	usePlugin:{
		swfupload:{},
		datepicker:{},
		passwordstrength:{},
		jqtransform:{
			selector:"select,input"
		}
	},
	beforeCheck:function(curform){
		//在表单提交执行验证之前执行的函数,curform参数是当前表单对象。
		//这里明确return false的话将不会继续执行验证操作;	
	},
	beforeSubmit:function(curform){
		//在验证成功后,表单提交前执行的函数,curform参数是当前表单对象。
		//这里明确return false的话表单将不会提交;	
	},
	callback:function(data){
		//返回数据data是json对象,{"info":"demo info","status":"y"}
		//info: 输出提示信息;
		//status: 返回提交数据的状态,是否提交成功。如可以用"y"表示提交成功,"n"表示提交失败,在ajax_post.php文件返回数据里自定字符,主要用在callback函数里根据该值执行相应的回调操作;
		//你也可以在ajax_post.php文件返回更多信息在这里获取,进行相应操作;
		//ajax遇到服务端错误时也会执行回调,这时的data是{ status:**, statusText:**, readyState:**, responseText:** };
 
		//这里执行回调操作;
		//注意:如果不是ajax方式提交表单,传入callback,这时data参数是当前表单对象,回调函数会在表单验证全部通过后执行,然后判断是否提交表单,如果callback里明确return false,则表单不会提交,如果return true或没有return,则会提交表单。
	}
});
————————————————
版权声明:本文为优快云博主「JERSENLEIBOY」的原创文章。
原文链接:https://blog.youkuaiyun.com/qq_31873539/article/details/83268049

说明:
datatype
内置基本的datatype类型有: * | *6-16 | n | n6-16 | s | s6-18 | p | m | e | url

*6-16:检测是否为6到16位任意字符;

 <input type="text" value="" name="name" datatype="*2-16" nullmsg="权限描述不能为空"/>

*:检测是否有输入,可以输入任何字符,不留空即可通过验证;
n:数字类型;
n6-16:6到16位数字;
s:字符串类型;
s6-18:6到18位字符串;
p:验证是否为邮政编码;
m:手机号码格式;
e:email格式;
url:验证字符串是否为网址。
自定义datatype的名称,可以由字母、数字、下划线、中划线和*号组成。

形如"*6-16"的datatype,Validform会自动扩展,可以指定任意的数值范围。如内置基本类型有"*6-16",那么你绑定datatype="*4-12"就表示4到12位任意字符。如果你自定义了一个datatype="zh2-4",表示2到4位中文字符,那么datatype="zh2-6"就表示2到6位中文字符。

5.2版本之后,datatype支持规则累加或单选。用","分隔表示规则累加;用"|"分隔表示规则多选一,即只要符合其中一个规则就可以通过验证,绑定的规则会依次验证,只要验证通过,后面的规则就会忽略不再比较。如绑定datatype="m|e",表示既可以填写手机号码,也能填写邮箱地址,如果知道填入的是手机号码,那么就不会再检测他是不是邮箱地址;datatype="zh,s2-4",表示要符合自定义类型"zh",也要符合规则"s2-4"。

注: 
5.2.1版本之后,datatype支持:
直接绑定正则:如可用这样写datatype="/\w{3,6}/i",要求是3到6位的字母,不区分大小写;
支持简单的逻辑运算:如datatype="m | e, *4-18 | /\w{3,6}/i | /^validform\.rjboy\.cn$/",
这个表达式的意思是:可以是手机号码;或者是邮箱地址,但字符长度必须在4到18位;或者是3到6位的字母,不区分大小写;或者输入validform.rjboy.cn,区分大小写。这里","分隔相当于逻辑运算里的"&&"; "|"分隔相当于逻辑运算里的"||";不支持括号运算。

nullmsg
当表单元素值为空时的提示信息,不绑定,默认提示"请填入信息!"。
如:nullmsg="请填写用户名!"
5.3版开始,对于没有绑定nullmsg的对象,会自动查找class为Validform_label下的文字作为提示文字:
如这样的html结构:
<span class="Validform_label">*用户名:</span><input type="text" val="" datatype="s" />
当这个文本框里没有输入时的出错信息就会是:"请输入用户名!"
这里Validform_label跟input之间的位置关系,不一定是要同级关系,同级里没有找到的话,它还会在同级的子级、父级的同级、父级的同级的子级里查找。
sucmsg 5.3+
当表单元素通过验证时的提示信息,不绑定,默认提示"通过信息验证!"。
如:sucmsg="用户名还未被使用,可以注册!"
5.3版开始,也可以在实时验证返回的json数据里返回成功的提示文字,请查看附加属性ajaxurl的介绍。
errormsg
输入内容不能通过验证时的提示信息,默认提示"请输入正确信息!"。
如:errormsg="用户名必须是2到4位中文字符!"
5.3版开始,Validform可以根据你绑定的datatype智能的输出相应出错信息,具体介绍请查看tipmsg
ignore
绑定了ignore="ignore"的表单元素,在有输入时,会验证所填数据是否符合datatype所指定数据类型,
没有填写内容时则会忽略对它的验证;
recheck
表单里面经常需要检查两次密码输入是否一致,recheck就是用来指定需要比较的另外一个表单元素。
如:recheck="password1",那么它就会拿当前元素的值跟该表单下,name为"password1"的元素比较。
tip
表单里经常有些文本框需要默认就显示一个灰色的提示文字,当获得焦点时提示文字消失,失去焦点时提示文字显示。tip属性就是用来实现这个效果。它通常和altercss搭配使用。
如<input type="text" value="默认提示文字" class="gray intxt" tip="默认提示文字" altercss="gray" />
altercss
它需要和tip属性配合使用,altercss指定的样式名,会在文本框获得焦点时被删除,没有输入内容而失去焦点时重新加上。
ajaxurl
指定ajax实时验证的后台文件的地址。
后台页面如valid.php文件中可以用 $_POST["param"] 接收到值,Ajax中会POST过来变量param和name。param是文本框的值,name是文本框的name属性。
5.2版本开始,可以在ajaxurl指定的url后绑定参数,如:ajaxurl="valid.php?myparam1=value1&myparam2=value2"; 5.3.1开始,地址后面附带的参数内部不再做另外解析,仍附带在地址后面,所以需要用GET方式去获取地址后面带的参数。
5.3之前的版本中,该文件输出的字符会作为错误信息显示在页面上,如果验证通过需输出小写字母"y"。
在5.3版中,实时验证的返回数据做了调整,须是含有status值的json数据!跟callback里的ajax返回数据格式统一,建议不再返回字符串"y"或"n"。目前这两种格式的数据都兼容。
注: 
如果ajax校验通过,会在该元素上绑定validform_valid值为true。可以通过设置该值来控制验证能不能通过,如验证码的验证,第一次验证通过后,不小心右点击了下验证码图片,验证码换了,但是仍然指示这个对象已经通过了验证,这时可以手动调整该值:$("#name")[0].validform_valid="false"。
怎样设置ajax的参数,具体可以查看Validform对象的config方法。
————————————————
版权声明:本文为优快云博主「zgphacker2010」的原创文章
原文链接:https://blog.youkuaiyun.com/zgphacker2010/article/details/100677430

### Vue2 中实现 el-form 表单验证 在 Vue2 中,`el-form` 和 `el-form-item` 是 Element UI 提供的核心组件之一,用于构建复杂的表单并支持内置的验证功能。以下是关于如何在 Vue2 中实现 `el-form` 表单验证的具体方法及示例。 #### 1. 绑定表单模型和验证规则 通过设置 `:model` 属性绑定表单的数据对象,并使用 `:rules` 属性定义验证规则。每个 `el-form-item` 需要指定对应的字段名作为 `prop` 属性值以便关联到验证规则[^1]。 ```html <template> <el-form :model="form" :rules="rules" ref="form"> <!-- 用户名输入框 --> <el-form-item label="用户名" prop="username"> <el-input v-model="form.username"></el-input> </el-form-item> <!-- 密码输入框 --> <el-form-item label="密码" prop="password"> <el-input type="password" v-model="form.password"></el-input> </el-form-item> <!-- 提交按钮 --> <el-button type="primary" @click="handleSubmit">提交</el-button> </el-form> </template> ``` #### 2. 定义数据结构与验证规则 在 Vue 实例中初始化表单数据以及相应的验证规则。验证规则可以包含多种条件,例如必填项、长度限制等。 ```javascript export default { data() { return { form: { username: '', password: '' }, rules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, // 必填项 { min: 3, max: 10, message: '长度应在 3 到 10 个字符之间', trigger: 'blur' } // 字符串长度约束 ], password: [ { required: true, message: '请输入密码', trigger: 'blur' } ] } }; }, methods: { handleSubmit() { this.$refs.form.validate((valid) => { if (valid) { console.log('表单验证成功'); // 执行后续操作,比如发送请求给后端 } else { console.log('表单验证失败'); return false; } }); } } }; ``` 上述代码展示了如何创建一个简单的登录表单,并为其添加基本的验证逻辑。当用户点击“提交”按钮时,会触发 `validate` 方法来执行验证流程[^2]。 #### 3. 图片上传场景下的应用实例 如果需要处理更复杂的情况,例如图片上传,则可以在 `el-form-item` 内嵌入自定义控件(如 `<input>`),并通过监听事件更新表单中的对应属性值[^3]。 ```html <template> <el-form :model="form" :rules="rules" ref="uploadForm"> <el-form-item label="头像" prop="avatar"> <input type="file" @change="handleAvatarChange" /> <img :src="form.avatar || placeholderImage" alt="Preview" width="100"/> </el-form-item> <el-button type="success" @click="submitUpload">上传</el-button> </el-form> </template> <script> export default { data() { return { placeholderImage: '/path/to/default-avatar.png', form: { avatar: null, }, rules: { avatar: [{ required: true, message: '请选择一张图片!', trigger: ['change'] }] } }; }, methods: { handleAvatarChange(event) { const file = event.target.files[0]; if (!file.type.startsWith('image/')) { alert('仅允许上传图片文件!'); return; } this.form.avatar = URL.createObjectURL(file); }, submitUpload() { this.$refs.uploadForm.validate(valid => { if (valid) { console.log('准备上传:', this.form.avatar); } else { console.error('验证未通过'); } }); } } } </script> ``` 此部分扩展了基础概念至实际开发需求——即结合前端框架完成多媒体资源管理的同时保持用户体验友好度。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值