Validform使用入门(2),web开发工具

1、Validform有非压缩、压缩和NCR三个版本提供下载,NCR是通用版,当你页面因编码问题,提示文字出现乱码时可以使用这个版本;

2、Validform没有限定必须使用table结构,它可以适用于任何结构,需要在tiptype中定义好位置关系。

绑定附加属性

凡要验证格式的元素均需绑定datatype属性,datatype可选值内置有10类,用来指定不同的验证格式。

如果还不能满足您的验证需求,可以传入自定义datatype,自定义datatype是一个非常强大的功能,通过它可以满足你的任何需求。

可以绑定的附加属性有:datatype、nullmsg、sucmsg、errormsg、ignore、recheck、tip、altercss、ajaxurl 和 plugin

绑定方法如下所示:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

 

<!--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>

<!--使用DatePicker插件-->

<input type="text" plugin="datepicker" class="inputxt" name="birthday" value="">

说明:

  • datatype

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

*:检测是否有输入,可以输入任何字符,不留空即可通过验证;

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

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结构:

*用户名:

当这个文本框里没有输入时的出错信息就会是:“请输入用户名!”

这里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搭配使用。

  • 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方法。

  • plugin

指定需要使用的插件。

5.3版开始,对于日期、swfupload和密码强度检测这三个插件,绑定了plugin属性即可以初始化对应的插件,可以不用在validform初始化时传入空的usePlugin了。

如,你要使用日期插件,5.3之前版本需要这样初始化:

$(“.demoform”).Validform({

usePlugin:{

datepicker:{}

}

});

5.3版开始,不需要传入这些空对象了,只需在表单元素上绑定plugin="datepicker"就可以,初始化直接这样:

$(“.demoform”).Validform();

初始化参数说明

所有可用参数如下:

 

1

2

 

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

 

$(".demoform").Validform({

btnSubmit:"#btn_sub",

btnReset:".btn_reset",

tiptype:1,

ignoreHidden:false,

dragonfly:false,

tipSweep:true,

label:".label",

showAllError:false,

postonce:true,

ajaxPost:true,

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,则会提交表单。

}});

参数说明:【所有参数均为可选项】

  • 必须是表单对象执行Validform方法,示例中".demoform"就是绑定在form元素上的class名称;

  • btnSubmit

指定当前表单下的哪一个按钮触发表单提交事件,如果表单下有submit按钮时可以省略该参数。示例中".btn_sub"是该表单下要绑定点击提交表单事件的按钮;

  • btnReset

".btn_reset"是该表单下要绑定点击重置表单事件的按钮;

  • tiptype

可用的值有:1、2、3、4和function函数,默认tiptype为1。 3、4是5.2.1版本新增

1=> 自定义弹出框提示;

2=> 侧边提示(会在当前元素的父级的next对象的子级查找显示提示信息的对象,表单以ajax提交时会弹出自定义提示框显示表单提交状态);

3=> 侧边提示(会在当前元素的siblings对象中查找显示提示信息的对象,表单以ajax提交时会弹出自定义提示框显示表单提交状态);

4=> 侧边提示(会在当前元素的父级的next对象下查找显示提示信息的对象,表单以ajax提交时不显示表单的提交状态);

如果上面的4种提示方式不是你需要的,你可以给tiptype传入自定义函数。通过自定义函数,可以实现你想要的任何提示效果:

tiptype:function(msg,o,cssctl){

//msg:提示信息;

//o:{obj:*,type:*,curform:*},

//obj指向的是当前验证的表单元素(或表单对象,验证全部验证通过,提交表单时o.obj为该表单对象),

//type指示提示的状态,值为1、2、3、4, 1:正在检测/提交数据,2:通过验证,3:验证失败,4:提示ignore状态,

//curform为当前form对象;

//cssctl:内置的提示信息样式控制函数,该函数需传入两个参数:显示提示信息的对象 和 当前提示的状态(既形参o中的type);

}

具体参见demo页。

tiptype不为1时,Validform会查找class为"Validform_checktip"的标签显示提示信息。tiptype=1时,会自动创建弹出框显示提示信息。

Validform_checktip和表单元素之间的位置关系,会根据tiptype的值有对应的结构,上面已经做了说明。

5.3版本开始,如果页面里没有显示出错信息的标签,会根据tiptype值自动创建Validform_checktip对象。

  • ignoreHidden

可用值: true | false。

默认为false,当为true时对:hidden的表单元素将不做验证;

  • dragonfly

可用值: true | false。

默认false,当为true时,值为空时不做验证;

  • tipSweep

可用值: true | false。

默认为false, 5.3版中做了修正,在各种tiptype下, 为true时提示信息将只会在表单提交时触发显示,各表单元素blur时不会触发信息提示;

  • label 5.3.1+

选择符

在没有绑定nullmsg时查找要显示的提示文字,默认查找".Validform_label"下的文字;

  • showAllError

可用值: true | false。

默认为false,true:提交表单时所有错误提示信息都会显示;false:一碰到验证不通过的对象就会停止检测后面的元素,只显示该元素的错误信息;

  • postonce

可用值: true | false。

默认为false,指定是否开启二次提交防御,true开启,不指定则默认关闭;

为true时,在数据成功提交后,表单将不能再继续提交。

  • ajaxPost

可用值: true | false。

默认为false,使用ajax方式提交表单数据,将会把数据POST到config方法或表单action属性里设定的地址;

  • datatype

传入自定义datatype类型,可以是正则,也可以是函数。

datatyp:{

“zh2-4”:/^[\u4E00-\u9FA5\uf900-\ufa2d]{2,4}$/,

“phone”:function(gets,obj,curform,regxp){

//参数gets是获取到的表单元素值,

//obj为当前表单元素,

//curform为当前验证的表单,

//regxp为内置的一些正则表达式的引用。

//return false表示验证出错,没有return或者return true表示验证通过。

}

}

具体示例请参考demo页;

  • usePlugin

目前已整合swfupload、datepicker、passwordstrength和jqtransform四个插件,在这里传入这些插件使用时需 要传入的参数。datepicker在Validform内调用时另外扩展了几个比较实用的参数,具体请参考demo页;

  • beforeCheck(curform)

在表单提交执行验证之前执行的函数,curform参数获取到的是当前表单对象。

函数return false的话将不会继续执行验证操作;

  • beforeSubmit(curform)

在表单验证通过,提交表单数据之前执行的函数,data参数是当前表单对象。

函数return false的话表单将不会提交;

  • callback

在使用ajax提交表单数据时,数据提交后的回调函数。返回数据data是Json对象:

{“info”:“demo info”,“status”:“y”}

info: 输出提示信息,

status: 返回提交数据的状态,是否提交成功,"y"表示提交成功,"n"表示提交失败,在ajax_post.php文件返回数据里自定字符,主要用在 callback函数里根据该值执行相应的回调操作。你也可以在ajax_post.php文件返回更多信息在这里获取,进行相应操作;

如果不是ajax方式提交表单,传入callback,这时data参数是当前表单对象,回调函数会在表单验证全部通过后执行,然后判断是否提交表单,如 果callback里return false,则表单不会提交,如果return true或没有return,则会提交表单。

5.3版开始,ajax遇到服务端错误时也会执行回调,这时的data是{ status:**, statusText:**, readyState:**, responseText:** }

Validform对象[方法支持链式调用]

如示例 var demo=$(“.formsub”).Validform(),那么demo对象会有以下属性和方法可以调用:

tipmsg【object】

如:demo.tipmsg.s=“error! no message inputed.”;

通过该对象可以修改除 tit 以外的其他提示文字,这样可以实现同一个页面的不同表单使用不同的提示文字。

具体可修改的提示文字

$.Tipmsg={//默认提示文字;

tit:“提示信息”,

w:{

“*”:“不能为空!”,

“*6-16”:“请填写6到16位任意字符!”,

“n”:“请填写数字!”,

“n6-16”:“请填写6到16位数字!”,

“s”:“不能输入特殊字符!”,

“s6-18”:“请填写6到18位字符!”,

“p”:“请填写邮政编码!”,

“m”:“请填写手机号码!”,

“e”:“邮箱地址格式不对!”,

“url”:“请填写网址!”

},

def:“请填写正确信息!”,

undef:“datatype未定义!”,

reck:“两次输入的内容不一致!”,

r:“通过信息验证!”,

c:“正在检测信息…”,

s:“请{填写|选择}{0|信息}!”,

v:“所填信息没有经过验证,请稍后…”,

p:“正在提交数据…”

};

要修改tit(弹出框的标题文字)的话,可以这样:$.Tipmsg.tit=“Message Box”,则弹出框的标题文字会换成"Message Box"

注:5.3.2+

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
img

总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总

Z2OyZ-1710693918868)]
[外链图片转存中…(img-mP2dCMBU-1710693918869)]
[外链图片转存中…(img-NCW9R0cE-1710693918869)]
[外链图片转存中…(img-gep8kVmx-1710693918870)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
[外链图片转存中…(img-oi4NmMDJ-1710693918870)]

总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总

  • 21
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值