国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

FormValidate 表單驗(yàn)證功能代碼更新并提供下載

2024-05-06 14:17:25
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
FormValidate 功能更新

下載:
http://xiazai.Vevb.com/jslib/FormValidate.rar

更多用法,可參才:

http://jobj.googlecode.com/svn/trunk/FormValidate/demo.html

加入方法:
extend,
加入驗(yàn)證模式 4,同3,但是當(dāng)驗(yàn)證不通過(guò)時(shí),立即停止向下檢查。在模式3下,如果發(fā)生錯(cuò)誤,會(huì)把錯(cuò)誤記錄,并向下檢查,模式4就不向下檢查了。


用法:


<input type="text" name="name[0]" id="name[0]" ruleTpl="0" />
<input type="text" name="birthday[0]" id="birthday[0]" ruleTpl="1" />
。。。。。
。。。。。
var checkRule = [
{name:"name[0]", required:true, min:2, max:3, msg:"請(qǐng)輸入姓名!長(zhǎng)度必須大于2,小于3"},
{name:"birthday[0]",required:false, type:"Date", msg:"出生日期是可選項(xiàng),如果輸入,請(qǐng)輸入正確的日期"},
{name:"email[0]", required:false, type:"Email", msg:"郵件是可選項(xiàng),如果輸入,請(qǐng)輸入正確的郵件地址"},
{name:"scoreA[0]", required:true, type:"Num", min:0, max:100, msg:"語(yǔ)文分?jǐn)?shù)是必須項(xiàng),必須大于0小于100"},
{name:"scoreB[0]", required:true, type:"Num", min:0, max:100, msg:"數(shù)學(xué)分?jǐn)?shù)是必須項(xiàng),必須大于0小于100"},
{name:"scoreC[0]", required:true, type:"Num", min:0, max:100, msg:"英語(yǔ)分?jǐn)?shù)是必須項(xiàng),必須大于0小于100"}
];

JObj.plugin("FormValidate");
var va = JObj.Plugin.FormValidate;

va.extend(document.forms[0],"ruleTpl",checkRule);
return va.validate(document.forms[0],checkRule,4);

解釋:
為啥要這樣寫?
如果不動(dòng)態(tài)添加表單項(xiàng),可以把 va.extend這一句刪除。但是動(dòng)態(tài)添加表單項(xiàng)的話。。。新增的表單項(xiàng)無(wú)法指定。
這樣寫,就是跟據(jù) ruleTpl 所指定的為驗(yàn)證規(guī)則。這個(gè) ruleTpl可以是任何字符串(不是它的值),比如,如果把 ruleTpl換成 ttt,那么就要寫成:
va.extend(document.forms[0],'ttt',checkRule)
ruleTpl 是做為表單項(xiàng)的一個(gè)自定義 attribute 存在的,其值必須是 checkRule 的一個(gè)下標(biāo),如果這個(gè)下標(biāo)不存,則默認(rèn)不檢查這一項(xiàng)。否則就把選定的 checkRule的元素復(fù)制一遍,達(dá)到動(dòng)態(tài)添加驗(yàn)證規(guī)則的目的。

在添加這個(gè)功能的時(shí)候,遇到幾個(gè)有趣的問(wèn)題,下面我說(shuō)說(shuō):

1,地址引用,請(qǐng)不要運(yùn)行,說(shuō)出下面代碼中,變量 a 的值。

var a = [{name:1}];
var tmp = a.push(a[a.length - 1]);
a[tmp - 1].name = 2;
如果你說(shuō):a = [{name:1},{name:2}],那你就大錯(cuò)特錯(cuò)了,真實(shí)值是:
a = [{name:2},{name:2}];

原因很簡(jiǎn)單,因?yàn)?push的是一個(gè)對(duì)象,對(duì)象在JS里是地址引用,所以, a[tmp - 1].name = 2 的時(shí)候,其實(shí)是把 a[0] 的值改變了。

下面這一段就很簡(jiǎn)單了,值引用,不會(huì)發(fā)生上面的情況。


var a = [1,2,3];
a.push(a[a.length - 1]);
alert(a);
a[a.length - 1] = 4;
alert(a);
2,F(xiàn)F下動(dòng)態(tài)刪除表單項(xiàng)。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 霸州市| 建水县| 始兴县| 新闻| 平陆县| 密云县| 新河县| 利辛县| 新兴县| 南宁市| 湖北省| 江川县| 土默特右旗| 松潘县| 渑池县| 和静县| 南投市| 家居| 巴彦淖尔市| 罗源县| 弥勒县| 绥德县| 江阴市| 广宗县| 宣汉县| 股票| 通渭县| 永仁县| 江西省| 迭部县| 阿拉善盟| 琼海市| 砚山县| 乐清市| 木里| 和平区| 潜山县| 准格尔旗| 宜良县| 博罗县| 钟山县|