Validform使用入門

Validform使用入門

1、引入css

請查看下載文件中的style.css,把里面Validform必須部分復制到你的css中(文件里這個注釋 "/*==========以下部分是Validform必須的===========*/" 之后的部分是必須的)。之前發現有部分網友把整個style.css都引用在了頁面里,然后發現樣式沖突了。

2、引入js (jquery 1.4.3 以上版本都可以)

?

?

1

2

<script type="text/javascript" src="http://validform.rjboy.cn/wp-content/themes/validform/js/jquery-1.6.2.min.js"></script><script type="text/javascript" src="http://validform.rjboy.cn/Validform/v5.1/Validform_v5.1_min.js"></script>

?

3、給需要驗證的表單元素綁定附加屬性

?

?

1

2

3

?

<form class="demoform">

<input type="text" value="" name="name" datatype="s5-16" errormsg="昵稱至少5個字符,最多16個字符!" />

</form>

?

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

綁定方法如下所示:

?

?

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結構:

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

  • 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+

$.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屬性中擴展默認提示信息是個很好的選擇。

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}$|14[0-9]{9}|15[0-9]{9}$|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:** };

//obj是當前表單的jquery對象;

}

},

ajaxurl:{

success:function(data,obj){

//data是返回的json數據;

//obj是當前正做實時驗證表單元素的jquery對象;

//注意:5.3版中,實時驗證的返回數據須是含有status值的json數據!

//跟callback里的ajax返回數據格式統一,建議不再返回字符串"y"或"n"。目前這兩種格式的數據都兼容。

}

}

}

調用外部插件

文件上傳 - swfupload

選擇文件后立即上傳

表單驗證通過后上傳文件

密碼強度檢測 - passwordStrength

密碼強度提示與驗證提示同時顯示

在符合驗證要求時才有密碼強度提示

日期控件 - datePicker

默認效果

選擇日期后執行回調函數

表單美化 - jqtransform

默認對所有元素美化

美化指定的表單元素

Validform的公用對象

$.Datatype

可以通過$.Datatype對象來擴展datatype類型。

如$.Datatype.zh=/^[\u4E00-\u9FA5\uf900-\ufa2d]{1,}$/

$.Tipmsg

可以通過$.Tipmsg對象來修改默認提示文字。具體可修改的提示文字請查看Validform對象的tipmsg屬性。

如果Validform對象的tipmsg屬性沒有找到相關的提示信息,那么就會到$.Tipmsg中查找對應提示文字。

如$.Tipmsg.tit="msg box"; //設置默認彈出框的標題文字。

$.Showmsg(msg)

調用Validform自定義的彈出框。

參數msg是要顯示的提示文字。

如$.Showmsg("這是提示文字"); //如果不傳入信息則不會有彈出框出現,像$.Showmsg()這樣是不會彈出提示框的。

$.Hidemsg()

關閉Validform自定義的彈出框。

如$.Hidemsg()

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/248821.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/248821.shtml
英文地址,請注明出處:http://en.pswp.cn/news/248821.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java爬取并下載酷狗音樂

本文方法及代碼僅供學習&#xff0c;僅供學習。 案例&#xff1a; 下載酷狗TOP500歌曲&#xff0c;代碼用到的代碼庫包含&#xff1a;Jsoup、HttpClient、fastJson等。 正文&#xff1a; 1、分析是否可以獲取到TOP500歌單 打開酷狗首頁&#xff0c;查看TOP500&#xff0c;發現存…

C 表達式及返回值

以下程序的輸出結果是__A____。 #include<stdio.h> main() {int i10,j10;printf("%d,%d\n",i,j--); } A、11,10 B、9,10 C、010,9 D、10,9 8.若變量a、i已正確定義&#xff0c;且i已正確賦值&#xff0c;合法的語句是___B___。 A、a1 B、i; C、…

Webpack/Vue-cli兩種方式加載markdown文件并實現代碼高亮

準備的資源&#xff1a; highlight.js &#xff1a; 實現代碼高亮&#xff0c;通過npm install highlight.js -D安裝 vue-markdown-loader&#xff1a;解析md文件的必備loader&#xff0c;通過npm install vue-markdown-loader -D安裝 下面我們分兩個場景來說明一下md文件的…

新浪微博第三方登陸重定向錯誤23123

新浪微博第三方登陸重定向錯誤23123 2019年06月02日 13:49:43 溫室花朵 閱讀數&#xff1a;2更多 個人分類&#xff1a; 第三方微博登陸21323編輯當我們使用微博第三方登陸的時候&#xff0c;發現登陸出錯了&#xff0c;錯誤碼為&#xff1a;21323&#xff0c;解決方案如下&…

Utility Manager 的一些百度不了的操作

一進來是不是這樣的&#xff01; 那突然出了點問題&#xff0c;咋辦呢&#xff01; 就像這樣子的&#xff0c; 恢復默認布局就OK啦&#xff01;哈哈哈&#xff0c;太聰明啦&#xff0c;但是百度了好長時間還是找不到啊&#xff0c;怎么辦吶&#xff0c;煩死啦&#xff01; 其實…

Echart 5.0+版本報錯Error in data(): “TypeError: Cannot read properties of undefined (reading ‘graphic‘)“

首先第一步需要檢查echarts的導入方式&#xff0c;在5.0以后的版本&#xff0c;echarts做了比較大的調整&#xff0c;在vue中引入時必須使用如下命令 // import echarts from echarts 這種方式高版本不支持import * as echarts from echartsvue.prototype.$echarts echarts其次…

記錄一次內網滲透試驗

0x00 前言 目標&#xff1a;給了一個目標機ip&#xff0c;要求得到該服務器權限&#xff0c;并通過該ip滲透至內網控制內網的兩臺服務器 攻擊機&#xff1a;kali (192.168.31.51) 目標機&#xff1a;windows 2003 (192.168.31.196) 0x01 信息收集 nmap端口探測 御劍后臺掃描 …

2018-2019 1 20165203 實驗五 通用協議設計

2018-2019 1 20165203 實驗五 通用協議設計 OpenSSL學習 定義&#xff1a;OpenSSL是為網絡通信提供安全及數據完整性的一種安全協議&#xff0c;囊括了主要的密碼算法、常用的密鑰和證書封裝管理功能以及SSL協議&#xff0c;并提供了豐富的應用程序供測試或其它目的使用。基本功…

弄懂webpack,只要看這一片就夠了(文末有福利)

什么是webpack ? webpack是什么&#xff0c;官網中是這么說的。 ? 本質上&#xff0c;webpack 是一個現代 JavaScript 應用程序的靜態模塊打包器(module bundler)。當 webpack 處理應用程序時&#xff0c;它會遞歸地構建一個依賴關系圖(dependency graph)&#xff0c;其中包…

beta沖刺總結那周余嘉熊掌將得隊

作業格式 課程名稱&#xff1a;軟件工程1916|W&#xff08;福州大學&#xff09;作業要求&#xff1a;項目Beta沖刺團隊名稱&#xff1a; 那周余嘉熊掌將得隊作業目標&#xff1a;beta沖刺總結隊員學號隊員姓名博客地址備注221600131Jaminhttps://www.cnblogs.com/JaminWu/隊長…

在Winform中菜單動態添加“最近使用文件”

最近在做文件處理系統中&#xff0c;要把最近打開文件顯示出來&#xff0c;方便用戶使用。網上資料有說&#xff0c;去遍歷“C:\Documents and Settings\Administrator\Recent”下的最近文檔本。文主要介紹在Winform界面菜單中實現【最近使用的文件】動態菜單的處理&#xff0c…

Vue組件通信原理剖析(一)事件總線的基石 $on和$emit

首先我們先從一個面試題入手。 面試官問&#xff1a; “Vue中組件通信的常用方式有哪些&#xff1f;” 我答&#xff1a; 1. props 2. 自定義事件 3. eventbus 4. vuex 5. 還有常見的邊界情況$parent、$children、$root、$refs、provide/inject 6. 此外還有一些非props特性$att…

display:flex彈性布局

一、背景 前段時間幫公司運維小姑娘調整她自己寫的頁面樣式時發現她用了display: flex&#xff0c;我這個后端老古董還不太懂flex&#xff0c;自愧不如啊&#xff0c;所以寫篇博客記錄學習下。 現在寫的前端頁面還停留在依賴 display 屬性 position屬性 float屬性的布局方式&…

一些好的思維方式

定理s 一、墨菲定律 觀點&#xff1a;1.任何事都沒有表面看起來那么簡單&#xff1b;2.所有的事都會比你預計的時間長&#xff1b;3.會出錯的事總會出錯&#xff1b;4.如果你擔心某種情況發生&#xff0c;那么它就更有可能發生。 墨菲定律的核心觀點就4點&#xff0c;不算復雜&…

Vue組件通信原理剖析(二)全局狀態管理Vuex

首先我們先從一個面試題入手。 面試官問&#xff1a; “Vue中組件通信的常用方式有哪些&#xff1f;” 我答&#xff1a; 1. props 2. 自定義事件 3. eventbus 4. vuex 5. 還有常見的邊界情況$parent、$children、$root、$refs、provide/inject 6. 此外還有一些非props特性$att…

初識單點登錄及JWT實現

單點登錄 多系統&#xff0c;單一位置登錄&#xff0c;實現多系統同時登錄的一種技術 &#xff08;三方登錄&#xff1a;某系統使用其他系統的用戶&#xff0c;實現本系統登錄的方式。如微信登錄、支付寶登錄&#xff09; 單點登錄一般是用于互相授信的系統&#xff0c;實現單一…

Vue組件通信原理剖析(三)provide/inject原理分析

首先我們先從一個面試題入手。 面試官問&#xff1a; “Vue中組件通信的常用方式有哪些&#xff1f;” 我答&#xff1a; 1. props 2. 自定義事件 3. eventbus 4. vuex 5. 還有常見的邊界情況$parent、$children、$root、$refs、provide/inject 6. 此外還有一些非props特性$att…

iMX6開發板-uboot-網絡設置和測試

本文章基于迅為IMX6開發板 將iMX6開發板通過網線連接到路由器&#xff0c;同時連接好調試串口&#xff0c;上電立即按 enter&#xff0c;即可進入 uboot。然后輸入命令 pri&#xff0c;查看開發板當前的配置&#xff0c;如下圖所示可以看到 ip 地址、子網掩碼 等信息。 本文檔測…

Django ajax 檢測用戶名是否已被注冊

添加一個 register.html 頁面 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body> <form><p>用戶名<input id"username" type&…

pyqt5控件

背景色設置 self.tab.setStyleSheet("background: rgb(238, 233, 233)") self.but_0.setStyleSheet("background: rgb(0, 255, 255)")樣式&#xff1a; self.but_0.setStyle(QStyleFactory.create("Windows"))字體&#xff1a; self.lineEdit.se…