validform 关闭提示sucmsg 怎么能不提示

匿名用户不能发表回复!|
每天回帖即可获得10分可用分!小技巧:
你还可以输入10000个字符
(Ctrl+Enter)
请遵守CSDN,不得违反国家法律法规。
转载文章请注明出自“CSDN(www.csdn.net)”。如是商业用途请联系原作者。当我们写提交表单的时候往往需要验证表单是否填写了内容,是否正确,这个插件可以很方便的完成我们需要的验证!
&script type="text/javascript" src="/js/jquery-1.6.2.min.js"&&/script&
&script type="text/javascript" src="/js/Validform_v5.1_min.js"&&/script&
2.给需要验证的表单元素附加datatype
&form class="demoform"&
&input type="text" value="" name="name" datatype="s5-16" errormsg="昵称至少5个字符,最多16个字符!" /&
&script type="text/javascript"&
$(function(){
$("#demoform").Validform();
凡要验证格式的元素均需绑定datatype属性,datatype可选值内置有10类,用来指定不同的验证格式。如果还不能满足您的验证需求,可以传入自定义datatype,自定义datatype是一个非常强大的功能,通过它可以满足你的任何需求。
可以绑定的附加属性有:datatype、nullmsg、sucmsg、errormsg、ignore、recheck、tip、altercss、ajaxurl&和&plugin
&!--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:"&&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"。
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智能的输出相应出错信息,具体介绍请查看
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属性。
阅读(...) 评论()1153人阅读
★.NET(16)
&%@ Page Language=&C#& AutoEventWireup=&true& CodeBehind=&companyEdit.aspx.cs& Inherits=&DTcms.Web.panyEdit& %&
&!DOCTYPE html&
&html xmlns=&http://www.w3.org/1999/xhtml&&
&title&编辑信息&/title&
&script type=&text/javascript& src=&../../scripts/jquery/jquery-1.10.2.min.js&&&/script&
&script type=&text/javascript& src=&../../scripts/jquery/Validform_v5.3.2_min.js&&&/script&
&script type=&text/javascript& src=&../../scripts/lhgdialog/lhgdialog.js?skin=idialog&&&/script&
&script type=&text/javascript& src=&../../scripts/datepicker/WdatePicker.js&&&/script&
&script type=&text/javascript& src=&../../scripts/swfupload/swfupload.js&&&/script&
&script type=&text/javascript& src=&../../scripts/swfupload/swfupload.queue.js&&&/script&
&script type=&text/javascript& src=&../../scripts/swfupload/swfupload.handlers.js&&&/script&
&script type=&text/javascript& charset=&utf-8& src=&../../editor/kindeditor-min.js&&&/script&
&script type=&text/javascript& charset=&utf-8& src=&../../editor/lang/zh_CN.js&&&/script&
&script type=&text/javascript& src=&../js/layout.js&&&/script&
&link href=&../skin/default/style.css& rel=&stylesheet& type=&text/css& /&
&script type=&text/javascript&&
$(function () {
//初始化表单验证
$(&#form1&).initValidform();
//计算用户组价格
$(&#field_control_sell_price&).change(function () {
var sprice = $(this).val();
if (sprice & 0) {
$(&.groupprice&).each(function () {
var num = $(this).attr(&discount&) * sprice / 100;
$(this).val(ForDight(num, 2));
//初始化编辑器
var editor = KindEditor.create('.editor', {
width: '98%',
height: '350px',
resizeType: 1,
uploadJson: '../../tools/upload_ajax.ashx?action=EditorFile&IsWater=1',
fileManagerJson: '../../tools/upload_ajax.ashx?action=ManagerFile',
allowFileManager: true
var editorMini = KindEditor.create('.editor-mini', {
width: '98%',
height: '250px',
resizeType: 1,
uploadJson: '../../tools/upload_ajax.ashx?action=EditorFile&IsWater=1',
'fontname', 'fontsize', '|', 'forecolor', 'hilitecolor', 'bold', 'italic', 'underline',
'removeformat', '|', 'justifyleft', 'justifycenter', 'justifyright', 'insertorderedlist',
'insertunorderedlist', '|', 'emoticons', 'image', 'link']
//初始化上传控件
$(&.upload-img&).each(function () {
$(this).InitSWFUpload({ sendurl: &../../tools/upload_ajax.ashx&, flashurl: &../../scripts/swfupload/swfupload.swf& });
$(&.upload-album&).each(function () {
$(this).InitSWFUpload({ btntext: &批量上传&, btnwidth: 66, single: false, water: true, thumbnail: true, filesize: &2048&, sendurl: &../../tools/upload_ajax.ashx&, flashurl: &../../scripts/swfupload/swfupload.swf&, filetypes: &*.*.*.*.& });
$(&.attach-btn&).click(function () {
showAttachDialog();
//设置封面图片的样式
$(&.photo-list ul li .img-box img&).each(function () {
if ($(this).attr(&src&) == $(&#hidFocusPhoto&).val()) {
$(this).parent().addClass(&selected&);
//创建附件窗口
function showAttachDialog(obj) {
var objNum = arguments.
var attachDialog = $.dialog({
id: 'attachDialogId',
lock: true,
max: false,
min: false,
title: &上传附件&,
content: 'url:dialog/dialog_attach.aspx',
width: 500,
height: 180
//如果是修改状态,将对象传进去
if (objNum == 1) {
attachDialog.data =
//删除附件节点
function delAttachNode(obj) {
$(obj).parent().remove();
&body class=&mainbody&&
&form id=&form1& runat=&server&&
&!--导航栏--&
&div class=&location&&
&a href=&school_list.aspx& class=&back&&&i&&/i&&span&
返回列表页&/span&&/a& &a href=&../center.aspx& class=&home&&&i&&/i&&span&首页&/span&&/a&
&i class=&arrow&&&/i&&a href=&homework_list.aspx&&&span&
内容管理&/span&&/a& &i class=&arrow&&&/i&&span&编辑信息&/span&
&div class=&line10&&
&!--/导航栏--&
&!--内容--&
&div class=&content-tab-wrap&&
&div id=&floatHead& class=&content-tab&&
&div class=&content-tab-ul-wrap&&
&li&&a href=&javascript:;& onclick=&tabs(this);& class=&selected&&基本信息&/a&&/li&
&div id=&editview& runat=&server& class=&tab-content&&
&dt&公司名称&/dt&
&asp:TextBox ID=&appName& runat=&server& CssClass=&input normal& datatype=&*2-100&
sucmsg=& & /&
&span class=&Validform_checktip&&*标题最多100个字符&/span&
&dt&联系电话&/dt&
&asp:TextBox ID=&appShName& runat=&server& CssClass=&input normal& datatype=&*2-100&
sucmsg=& & /&
&span class=&Validform_checktip&&*标题最多100个字符(不可更改)&/span&
&dt&公司地址&/dt&
&asp:TextBox ID=&TextBox1& runat=&server& CssClass=&input normal& datatype=&*2-100&
sucmsg=& & /&
&span class=&Validform_checktip&&*标题最多100个字符(不可更改)&/span&
&dl id=&textView&
runat=&server&&
&dt&公司简介&/dt&
&asp:TextBox ID=&txtSendEmail& runat=&server& CssClass=&input& TextMode=&MultiLine&
datatype=&*0-255& sucmsg=& &&&/asp:TextBox&
&span class=&Validform_checktip&&公司简介,255个字符以内&/span&
&div id=&field_tab_content& runat=&server& visible=&false& class=&tab-content& style=&display: none&&
&!--/内容--&
&!--工具栏--&
&div id=&foottool& runat=&server& class=&page-footer&&
&div class=&btn-list&&
&asp:Button ID=&btnSubmit& runat=&server& Text=&提交保存& CssClass=&btn& OnClick=&btnSubmit_Click& /&
&input name=&btnReturn& type=&button& value=&返回上一页& class=&btn yellow& onclick=&javascript: history.back(-1);& /&
&div class=&clear&&
&!--/工具栏--&
using System.Collections.G
using System.C
using System.L
using System.W
using System.Web.UI;
using System.Web.UI.WebC
namespace DTcms.Web.admin.oacmp
public partial class companyEdit : Web.UI.ManagePage
private static string appRootPath = ConfigurationManager.AppSettings[&appRootPath&];
private string action = DTEnums.ActionEnum.Add.ToString(); //操作类型
protected string channel_name = string.E //频道名称
private int id = 0;
//页面加载事件
protected void Page_Load(object sender, EventArgs e)
string _action = DTRequest.GetQueryString(&action&);
if (!string.IsNullOrEmpty(_action) && _action == DTEnums.ActionEnum.Edit.ToString())
this.action = DTEnums.ActionEnum.Edit.ToString();//修改类型
this.id = DTRequest.GetQueryInt(&id&);
if (this.id == 0)
JscriptMsg(&传输参数不正确!&, &back&, &Error&);
if (!new BLL.oa_company().Exists(this.id))
JscriptMsg(&信息不存在或已被删除!&, &back&, &Error&);
if (!Page.IsPostBack)
NewsChkAdminLevel(); //检查权限
if (action == DTEnums.ActionEnum.Edit.ToString()) //修改
ShowInfo(this.id);
public void NewsChkAdminLevel()
Model.manager model = GetAdminInfo();
if (model.role_type &= 0)
string msgbox = &parent.jsdialog(\&错误提示\&, \&您没有管理该页面的权限,请勿非法进入!\&, \&back\&, \&Error\&)&;
Response.Write(&&script type=\&text/javascript\&&& + msgbox + &&/script&&);
Response.End();
#region 赋值操作=================================
private void ShowInfo(int _id)
BLL.oa_company bll = new BLL.oa_company();
Model.oa_company model = bll.GetModel(_id);
Model.manager modelMan = GetAdminInfo();
#endregion
#region 增加操作=================================
private bool DoAdd()
bool result =
Model.oa_company model = new Model.oa_company();
BLL.oa_company bll = new BLL.oa_company();
Model.manager modelMan = GetAdminInfo();
if (bll.Add(model) == true)
AddAdminLog(DTEnums.ActionEnum.Add.ToString(), &添加成功&); //记录日志
#endregion
#region 修改操作=================================
private bool DoEdit(int _id)
bool result =
BLL.oa_company bll = new BLL.oa_company();
Model.oa_company model = bll.GetModel(_id);
if (bll.Update(model))
AddAdminLog(DTEnums.ActionEnum.Edit.ToString(), &修改成功&); //记录日志
#endregion
protected void btnSubmit_Click(object sender, EventArgs e)
if (action == DTEnums.ActionEnum.Edit.ToString()) //修改
NewsChkAdminLevel(); //检查权限
if (!DoEdit(this.id))
JscriptMsg(&保存过程中发生错误啦!&, &&, &Error&);
JscriptMsg(&修改信息成功!&, &AppList.aspx&, &Success&);
else //添加
NewsChkAdminLevel(); //检查权限
if (!DoAdd())
JscriptMsg(&保存过程中发生错误啦!&, &&, &Error&);
JscriptMsg(&添加信息成功!&, &AppList.aspx&, &Success&);
Model.manager model = GetAdminInfo();
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:361894次
积分:8773
积分:8773
排名:第2286名
原创:461篇
转载:16篇
评论:47条
阅读:5416
(4)(1)(6)(4)(6)(3)(2)(3)(4)(1)(1)(1)(4)(1)(2)(4)(5)(2)(2)(3)(1)(4)(5)(1)(3)(3)(8)(4)(2)(1)(6)(12)(5)(4)(6)(2)(7)(6)(3)(2)(7)(8)(3)(3)(1)(16)(6)(10)(14)(12)(22)(225)(1)(1)(2)(2)
(window.slotbydup = window.slotbydup || []).push({
id: '4740881',
container: s,
size: '200,200',
display: 'inlay-fix'拒绝访问 |
| 百度云加速
请打开cookies.
此网站 () 的管理员禁止了您的访问。原因是您的访问包含了非浏览器特征(3b05fa-ua98).
重新安装浏览器,或使用别的浏览器Validform使用入门
我的图书馆
Validform使用入门
1、引入css
请查看下载文件中的style.css,把里面Validform必须部分复制到你的css中(文件里这个注释 "/*==========以下部分是Validform必须的===========*/" 之后的部分是必须的)。之前发现有部分网友把整个style.css都引用在了页面里,然后发现样式冲突了。
2、引入js (jquery 1.4.3 以上版本都可以)
&script type="text/javascript" src="/wp-content/themes/validform/js/jquery-1.6.2.min.js"&&/script&
&script type="text/javascript" src="/Validform/v5.1/Validform_v5.1_min.js"&&/script&
3、给需要验证的表单元素绑定附加属性
&form class="demoform"&
&input type="text" value="" name="name" datatype="s5-16" errormsg="昵称至少5个字符,最多16个字符!" /&
4、初始化,就这么简单
1$(".demoform").Validform();
1、Validform有非压缩、压缩和NCR三个版本提供下载,NCR是通用版,当你页面因编码问题,提示文字出现乱码时可以使用这个版本;
2、Validform没有限定必须使用table结构,它可以适用于任何结构,需要在tiptype中定义好位置关系。
凡要验证格式的元素均需绑定datatype属性,datatype可选值内置有10类,用来指定不同的验证格式。
如果还不能满足您的验证需求,可以传入自定义datatype,自定义datatype是一个非常强大的功能,通过它可以满足你的任何需求。
可以绑定的附加属性有:datatype、nullmsg、sucmsg、errormsg、ignore、recheck、tip、altercss、ajaxurl 和 plugin
绑定方法如下所示:
&!--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:"&&b&密码强度:&/b& &span&弱&/span&&span&中&/span&&span class="last"&强&/span&&/div&
&!--使用DatePicker插件--&
&input type="text" plugin="datepicker" class="inputxt" name="birthday" value=""&
内置基本的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位的字母,不区分大小写;或者输入,区分大小写。这里","分隔相当于逻辑运算里的"&&"; "|"分隔相当于逻辑运算里的"||";不支持括号运算。
当表单元素值为空时的提示信息,不绑定,默认提示"请填入信息!"。
如: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="用户名必须是2到4位中文字符!"
5.3版开始,Validform可以根据你绑定的datatype智能的输出相应出错信息,具体介绍请查看
绑定了ignore="ignore"的表单元素,在有输入时,会验证所填数据是否符合datatype所指定数据类型,没有填写内容时则会忽略对它的验证;
表单里面经常需要检查两次密码输入是否一致,recheck就是用来指定需要比较的另外一个表单元素。
如:recheck="password1",那么它就会拿当前元素的值跟该表单下,name为"password1"的元素比较。
表单里经常有些文本框需要默认就显示一个灰色的提示文字,当获得焦点时提示文字消失,失去焦点时提示文字显示。tip属性就是用来实现这个效果。它通常和altercss搭配使用。
如&input type="text" value="默认提示文字" class="gray intxt" tip="默认提示文字" altercss="gray" /&
它需要和tip属性配合使用,altercss指定的样式名,会在文本框获得焦点时被删除,没有输入内容而失去焦点时重新加上。
指定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对象的方法。
指定需要使用的插件。
5.3版开始,对于日期、swfupload和密码强度检测这三个插件,绑定了plugin属性即可以初始化对应的插件,可以不用在validform初始化时传入空的usePlugin了。
如,你要使用日期插件,5.3之前版本需要这样初始化:$(".demoform").Validform({
usePlugin:{
datepicker:{}
5.3版开始,不需要传入这些空对象了,只需在表单元素上绑定plugin="datepicker"就可以,初始化直接这样:
$(".demoform").Validform();
所有可用参数如下:
$(".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名称;
指定当前表单下的哪一个按钮触发表单提交事件,如果表单下有submit按钮时可以省略该参数。示例中".btn_sub"是该表单下要绑定点击提交表单事件的按钮;
".btn_reset"是该表单下要绑定点击重置表单事件的按钮;
可用的值有: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);
具体参见页。
tiptype不为1时,Validform会查找class为"Validform_checktip"的标签显示提示信息。tiptype=1时,会自动创建弹出框显示提示信息。
Validform_checktip和表单元素之间的位置关系,会根据tiptype的值有对应的结构,上面已经做了说明。
5.3版本开始,如果页面里没有显示出错信息的标签,会根据tiptype值自动创建Validform_checktip对象。
ignoreHidden
可用值: true | false。
默认为false,当为true时对:hidden的表单元素将不做验证;
可用值: true | false。
默认false,当为true时,值为空时不做验证;
可用值: true | false。
默认为false, 5.3版中做了修正,在各种tiptype下, 为true时提示信息将只会在表单提交时触发显示,各表单元素blur时不会触发信息提示;
label 5.3.1+
在没有绑定nullmsg时查找要显示的提示文字,默认查找".Validform_label"下的文字;
showAllError
可用值: true | false。
默认为false,true:提交表单时所有错误提示信息都会显示;false:一碰到验证不通过的对象就会停止检测后面的元素,只显示该元素的错误信息;
可用值: true | false。
默认为false,指定是否开启二次提交防御,true开启,不指定则默认关闭;
为true时,在数据成功提交后,表单将不能再继续提交。
可用值: true | false。
默认为false,使用ajax方式提交表单数据,将会把数据POST到config方法或表单action属性里设定的地址;
传入自定义datatype类型,可以是正则,也可以是函数。
"zh2-4":/^[\u4E00-\u9FA5\uf900-\ufa2d]{2,4}$/,
"phone":function(gets,obj,curform,regxp){
//参数gets是获取到的表单元素值,
//obj为当前表单元素,
//curform为当前验证的表单,
//regxp为内置的一些正则表达式的引用。
//return false表示验证出错,没有return或者return true表示验证通过。
具体示例请参考页;
目前已整合swfupload、datepicker、passwordstrength和jqtransform四个插件,在这里传入这些插件使用时需要传入的参数。datepicker在Validform内调用时另外扩展了几个比较实用的参数,具体请参考demo页;
beforeCheck(curform)
在表单提交执行验证之前执行的函数,curform参数获取到的是当前表单对象。
函数return false的话将不会继续执行验证操作;
beforeSubmit(curform)
在表单验证通过,提交表单数据之前执行的函数,data参数是当前表单对象。
函数return false的话表单将不会提交;
在使用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:** }
如示例 var demo=$(".formsub").Validform(),那么demo对象会有以下属性和方法可以调用:
【object】
如:demo.tipmsg.s="error! no message inputed.";
通过该对象可以修改除 tit 以外的其他提示文字,这样可以实现同一个页面的不同表单使用不同的提示文字。
具体可修改的提示文字
$.Tipmsg={//默认提示文字;
tit:"提示信息",
"*":"不能为空!",
"*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+
$.Tipmsg.w里,形如"*6-16"的提示文字,里面的数字是会被替换的。如绑定datatype="*2-18",那它默认的出错信息就会是"请填写2到18位任意字符!",可以通过$.Tipmsg.w或Validform对象的tipmsg属性修改和扩展默认错误信息,如果你已经设置了"zh2-4"的提示信息是"2-4位中文",那么"zh2-8"出错的信息就自动会是:"2-8位中文"。对于自定义的datatype,在扩展默认信息时,注意错误信息的名字要跟datatype名字一样,如上面示例是:$.Tipmsg.w["zh2-4"]="2-4位中文"。对于多页面或一个页面多表单有相同datatype来说,在$.Tipmsg.w或Validform对象的tipmsg属性中扩展默认提示信息是个很好的选择。
$.Tipmsg.s是用来指定在没有绑定nullmsg时的默认提示信息。"{0}"是会被找到的label参数指定的对象或Validform_label里的文字替换掉的,"{填写|选择}"里的文字在绑定了"recheck"属性的表单元素上检测时是会不显示的,当前验证对象是radio、checkbox或select时,会输出"选择",是其他类型的元素时会输出"填写"和后面的"信息"。
具体示例请参见页。
【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}$|14[0-9]{9}|15[0-9]{9}$|18[0-9]{9}$/,
"e":/^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,
"url":/^(\w+:\/\/)?\w+(\.\w+)+.*$/
【返回值: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对象下查找这些对象。
【返回值:Validform】
获取Validform对象的第n个元素。
如你页面上有多个form的class都是formsub,执行上面的验证绑定,得到的demo对象就可以操作所有这些表单,如果你要对其中某个表单执行某些操作,那么就可以使用这个方法。
如demo.eq(0).resetForm(),重置第一个表单。
【返回值:Validform】
以ajax方式提交表单。flag为true时,跳过验证直接提交,sync为true时将以同步的方式进行ajax提交。
参数url是5.3版新增,传入了url地址时,表单会提交到这个地址
如demo.ajaxPost(true),不做验证直接ajax提交表单。
【返回值:Validform】
终止ajax的提交。
如执行上面的ajaxPost()之后,发现某些项填写不对,想取消表单提交,那么就可以执行这个操作:demo.abort()
【返回值:Validform】
以初始化时传入参数的设置方式提交表单,flag为true时,跳过验证直接提交。
参数url是5.3版新增,传入了url地址时,表单会提交到这个地址
如demo.submitForm(true),不做验证直接提交表单。
【返回值:Validform】
重置表单。
如demo.resetForm(),重置表单到初始状态。
【返回值:Validform】
重置表单的提交状态。传入了postonce参数的话,表单成功提交后状态会设置为"posted",重置提交状态可以让表单继续可以提交。
如demo.resetStatus()
【返回值:String】
获取表单的提交状态,normal:未提交,posting:正在提交,posted:已成功提交过。
如demo.getStatus()
【返回值:Validform】
设置表单的提交状态,可以设置normal,posting,posted三种状态,不传参则设置状态为posting,这个状态表单可以验证,但不能提交。
如demo.setStatus("posted")
【返回值:Validform】
忽略对所选择对象的验证,不传入selector则忽略所有表单元素。
如demo.ignore("select,textarea,#name"),忽略Validform对象下所有select,textarea及一个id为"name"元素的验证。
【返回值:Validform】
将ignore方法所忽略验证的对象重新获取验证效果,不传入selector则恢复验证所有表单元素。
如demo.unignore("select,textarea,#name"),恢复Validform对象下所有select,textarea及一个id为"name"元素的验证。
【返回值:Boolean】
bool为true时则只验证不显示提示信息
对指定对象进行验证(默认验证当前整个表单),通过返回true,否则返回false(绑定实时验证的对象,格式符合要求时返回true,而不会等ajax的返回结果)
如demo.check(),验证当前整个表单,且只验证但不显示对错信息。
5.3+ 【返回值:Validform】
setup参数是一个对象。
demo.config({
showAllError:true,
url:"这里指定提交地址",
ajaxpost:{
//可以传入$.ajax()能使用的,除dataType外的所有参数;
//可以传入$.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();}});
②、执行config可以动态设置、添加参数,如:
demo.config({
$(".save").click(function(){
demo.config({
ajaxpost:{
timeout:1000
那么在点击save按钮后,demo所对应的表单的config={
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:{
timeout:1000,
success:function(data,obj){
//data是返回的json数据;
//obj是当前表单的jquery对象;
error:function(data,obj){
//data是{ status:**, statusText:**, readyState:**, responseText:** };
//obj是当前表单的jquery对象;
success:function(data,obj){
//data是返回的json数据;
//obj是当前正做实时验证表单元素的jquery对象;
//注意:5.3版中,实时验证的返回数据须是含有status值的json数据!
//跟callback里的ajax返回数据格式统一,建议不再返回字符串"y"或"n"。目前这两种格式的数据都兼容。
可以通过$.Datatype对象来扩展datatype类型。
如$.Datatype.zh=/^[\u4E00-\u9FA5\uf900-\ufa2d]{1,}$/
可以通过$.Tipmsg对象来修改默认提示文字。具体可修改的提示文字请查看Validform对象的tipmsg属性。
如果Validform对象的tipmsg属性没有找到相关的提示信息,那么就会到$.Tipmsg中查找对应提示文字。
如$.Tipmsg.tit="msg box"; //设置默认弹出框的标题文字。
调用Validform自定义的弹出框。
参数msg是要显示的提示文字。
如$.Showmsg("这是提示文字"); //如果不传入信息则不会有弹出框出现,像$.Showmsg()这样是不会弹出提示框的。
关闭Validform自定义的弹出框。
如$.Hidemsg()
馆藏&24373
TA的推荐TA的最新馆藏[转]&[转]&[转]&[转]&[转]&[转]&[转]&[转]&[转]&
喜欢该文的人也喜欢

我要回帖

更多关于 validform 的文章

 

随机推荐