HTML 表單中的驗證

凡要驗證格式的元素均需綁定datatype屬性,datatype可選值內置有10類,用來指定不一樣的驗證格式。php

若是還不能知足您的驗證需求,能夠傳入自定義datatype,自定義datatype是一個很是強大的功能,經過它能夠知足你的任何需求。css

能夠綁定的附加屬性有:datatype、nullmsg、sucmsg、errormsg、ignore、recheck、tip、altercss、ajaxurl 和 plugin等.html

說明:前端

內置基本的datatype類型有: | 6-16 | n | n6-16 | s | s6-18 | p | m | e | urlajax

*:檢測是否有輸入,能夠輸入任何字符,不留空便可經過驗證;json

*6-16:檢測是否爲6到16位任意字符;編碼

n:數字類型;url

n6-16:6到16位數字;spa

s:字符串類型;code

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><inputtype="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以前的版本中,該文件輸出的字符會做爲錯誤信息顯示在頁面上,若是驗證經過需輸出小寫字母"y"。

在5.3版中,實時驗證的返回數據作了調整,須是含有status值的json數據!跟callback裏的ajax返回數據格式統一,建議再也不返回字符串"y"或"n"。目前這兩種格式的數據都兼容。

注:

若是ajax校驗經過,會在該元素上綁定validform_valid值爲true。能夠經過設置該值來控制驗證能不能經過,如驗證碼的驗證,第一次驗證經過後,不當心右點擊了下驗證碼圖片,驗證碼換了,可是仍然指示這個對象已經經過了驗證,這時能夠手動調整該值:$("#name")[0].validform_valid="false"。

怎樣設置ajax的參數,具體能夠查看Validform對象的config方法。

 

公司的外網前端驗證

<label class="span1-5 control-label"><b class="mr5 red500">*</b>見習部門</label>
                            <div class="span2-5">
                                <input type="text" name="department" placeholder="請輸入見習部門" id="department" class="form-control" datatype="*1-20" nullmsg="請輸入見習部門"/>
                            </div>
                            <label class="span1-5 control-label"><b class="mr5 red500">*</b>崗位名稱</label>
                            <div class="span2-5">
                                <input type="text" name="positionname" placeholder="請輸入崗位名稱" class="form-control" datatype="*1-20" nullms="請輸入見習崗位名稱"/>
                            </div>
                            <label class="span1-5 control-label">
                                <b class="mr5 red500">*</b>需求人數</label>
                            <div class="span2-5">
                                <input type="text" id="neednum" name="neednum" placeholder="請輸入需求人數" class="form-control" datatype="n1-8" nullmsg="請輸入需求人數" />
                            </div>
                        </div>
相關文章
相關標籤/搜索