Validform使用入门(3),你知道多少

}

具体示例请参考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+

KaTeX parse error: Undefined control sequence: \* at position 15: .Tipmsg.w里,形如"\̲*̲6-16"的提示文字,里面的数….Tipmsg.w或Validform对象的tipmsg属性修改和扩展默认错误信息,如果你已经设置了"zh2-4"的提示信息是"2-4位 中文",那么"zh2-8"出错的信息就自动会是:“2-8位中文”。对于自定义的datatype,在扩展默认信息时,注意错误信息的名字要跟 datatype名字一样,如上面示例是:KaTeX parse error: Undefined control sequence: \[ at position 10: .Tipmsg.w\̲[̲"zh2-4"\]="2-4位….Tipmsg.w或Validform对象的tipmsg属性中扩展默认提示信息是个很好的选择。

5.3.1+

$.Tipmsg.s是用来指定在没有绑定nullmsg时的默认提示信息。“{0}“是会被找到的label参数指定的对象或 Validform_label里的文字替换掉的,”{填写|选择}“里的文字在绑定了"recheck"属性的表单元素上检测时是会不显示的,当前验证 对象是radio、checkbox或select时,会输出"选择”,是其他类型的元素时会输出"填写"和后面的"信息”。

具体示例请参见demo页。

dataType【object】

获取内置的一些正则:

{

“match”:/^(.+?)(\d+)-(\d+)$/,

“*”😕[\w\W]+/,

“*6-16”:/^[\w\W]{6,16}$/,

“n”:/^\d+$/,

“n6-16”:/^\d{6,16}$/,

“s”:/^[\u4E00-\u9FA5\uf900-\ufa2d\w\.\s]+$/,

“s6-18”:/^[\u4E00-\u9FA5\uf900-\ufa2d\w\.\s]{6,18}$/,

“p”:/^[0-9]{6}$/,

“m”:/^13[0-9]{9}KaTeX parse error: Undefined control sequence: \[ at position 4: |14\̲[̲0-9\]{9}|15\[0-…|18[0-9]{9}$/,

“e”:/^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,

“url”:/^(\w+:\/\/)?\w+(\.\w+)+.*$/

}

addRule(rule)【返回值:Validform】

可以通过Validform对象的这个方法来给表单元素绑定验证规则,绑定验证类型中列出的附加属性都可以通过这个方法绑定。

demo.addRule([

{

ele:“#name”,

datatype:“s6-18”,

ajaxurl:“valid.php”,

nullmsg:“请输入昵称!”,

errormsg:“昵称至少6个字符,最多18个字符!”

},

{

ele:“#userpassword”,

datatype:“*6-16”,

nullmsg:“请设置密码!”,

errormsg:“密码范围在6~16位之间!”

},

{

ele:“#userpassword2”,

datatype:“*”,

recheck:“userpassword”,

nullmsg:“请再输入一次密码!”,

errormsg:“您两次输入的账号密码不一致!”

}

]);

其中ele是指定要绑定规则的对象,会在Validform对象下查找这些对象。

eq(n)【返回值:Validform】

获取Validform对象的第n个元素。

如你页面上有多个form的class都是formsub,执行上面的验证绑定,得到的demo对象就可以操作所有这些表单,如果你要对其中某个表单执行某些操作,那么就可以使用这个方法。

如demo.eq(0).resetForm(),重置第一个表单。

ajaxPost(flag,sync,url)【返回值:Validform】

以ajax方式提交表单。flag为true时,跳过验证直接提交,sync为true时将以同步的方式进行ajax提交。

参数url是5.3版新增,传入了url地址时,表单会提交到这个地址

如demo.ajaxPost(true),不做验证直接ajax提交表单。

abort()【返回值:Validform】

终止ajax的提交。

如执行上面的ajaxPost()之后,发现某些项填写不对,想取消表单提交,那么就可以执行这个操作:demo.abort()

submitForm(flag,url)【返回值:Validform】

以初始化时传入参数的设置方式提交表单,flag为true时,跳过验证直接提交。

参数url是5.3版新增,传入了url地址时,表单会提交到这个地址

如demo.submitForm(true),不做验证直接提交表单。

resetForm()【返回值:Validform】

重置表单。

如demo.resetForm(),重置表单到初始状态。

resetStatus()【返回值:Validform】

重置表单的提交状态。传入了postonce参数的话,表单成功提交后状态会设置为"posted",重置提交状态可以让表单继续可以提交。

如demo.resetStatus()

getStatus()【返回值:String】

获取表单的提交状态,normal:未提交,posting:正在提交,posted:已成功提交过。

如demo.getStatus()

setStatus(status)【返回值:Validform】

设置表单的提交状态,可以设置normal,posting,posted三种状态,不传参则设置状态为posting,这个状态表单可以验证,但不能提交。

如demo.setStatus(“posted”)

ignore(selector)【返回值:Validform】

忽略对所选择对象的验证,不传入selector则忽略所有表单元素。

如demo.ignore(“select,textarea,#name”),忽略Validform对象下所有select,textarea及一个id为"name"元素的验证。

unignore(selector)【返回值:Validform】

将ignore方法所忽略验证的对象重新获取验证效果,不传入selector则恢复验证所有表单元素。

如demo.unignore(“select,textarea,#name”),恢复Validform对象下所有select,textarea及一个id为"name"元素的验证。

check(bool,selector)【返回值:Boolean】

bool为true时则只验证不显示提示信息

对指定对象进行验证(默认验证当前整个表单),通过返回true,否则返回false(绑定实时验证的对象,格式符合要求时返回true,而不会等ajax的返回结果)

如demo.check(),验证当前整个表单,且只验证但不显示对错信息。

config(setup) 5.3+ 【返回值:Validform】

setup参数是一个对象。

如:

demo.config({

showAllError:true,

url:“这里指定提交地址”,

ajaxpost:{

//可以传入$.ajax()能使用的,除dataType外的所有参数;

},

ajaxurl:{

//可以传入$.ajax()能使用的,除dataType外的所有参数;

}

})

可用参数:tiptype等 5.3.2+:可以在这里设置初始化可用的所有参数

url:指定表单的提交路径,这里指定的路径会覆盖表单action属性所指定的路径

ajaxpost:表单以ajax提交时,可以在这里配置ajax的参数

ajaxurl:配置实时验证ajax的参数

①、config方法还能为已经初始化过的表单重新配置参数了!5.3.2+

如var demo=$(“.formsub”).Validform();

demo.config({tiptype:2});

demo下的各表单还能分别配置不同参数!

如demo.eq(0).config({tiptype:1,ajaxPost:true});

demo.eq(1).config({tiptype:1,callback:function(curform){my_method_to_submit_form(); return false;}});

②、执行config可以动态设置、添加参数,如:

demo.config({

url:“http://validform.rjboy.cn”

});

$(“.save”).click(function(){

demo.config({

ajaxpost:{

timeout:1000

}

});

});

那么在点击save按钮后,demo所对应的表单的config={

url:“http://validform.rjboy.cn”,

ajaxpost:{

timeout:1000

}

}

③、参数url的优先级:form表单的action所指定的提交地址会被config.url覆盖,

config.url会被config.ajaxpost.url覆盖,config.ajaxpost.url会被Validform对象的方法submitForm(flag,url)

和ajaxPost(flag,sync,url)里的url覆盖。

如果表单里没有指定action提交地址,那么就会提交到config.url设定的地址。

考虑到整个验证框架的逻辑,传入dataType参数不会起作用,不会被覆盖,ajax必须返回含有status值的json数据。

④、另外注意的是:传入的success和error方法里,能多获取到一个参数,如:

demo.config={

ajaxpost:{

url:“”,

timeout:1000,

…,

success:function(data,obj){

//data是返回的json数据;

//obj是当前表单的jquery对象;

},

error:function(data,obj){

//data是{ status:**, statusText:**, readyState:**, responseText:** };

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

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

img
img
img
img

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

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

前端资料汇总

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

我一直觉得技术面试不是考试,考前背背题,发给你一张考卷,答完交卷等通知。

首先,技术面试是一个 认识自己 的过程,知道自己和外面世界的差距。

更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。
找工作无非就是看三点:和什么人、做什么事、给多少钱,要给这三者在自己的心里划分一个比例。
最后,祝愿大家在这并不友好的环境下都能找到自己心仪的归宿。
图片转存中…(img-YvUkOGYt-1710693954545)]
[外链图片转存中…(img-W5MHjrXF-1710693954545)]
[外链图片转存中…(img-7plINowc-1710693954546)]
[外链图片转存中…(img-i7RScgyw-1710693954546)]

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

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

前端资料汇总

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

我一直觉得技术面试不是考试,考前背背题,发给你一张考卷,答完交卷等通知。

首先,技术面试是一个 认识自己 的过程,知道自己和外面世界的差距。

更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。
找工作无非就是看三点:和什么人、做什么事、给多少钱,要给这三者在自己的心里划分一个比例。
最后,祝愿大家在这并不友好的环境下都能找到自己心仪的归宿。

  • 26
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值