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

首頁 > 編程 > JavaScript > 正文

jquery validate 自定義驗證方法介紹 日期驗證

2019-11-20 21:02:20
字體:
供稿:網(wǎng)友

jquery validate有很多驗證規(guī)則,但是更多的時候,需要根據(jù)特定的情況進行自定義驗證規(guī)則。

這里就來聊一聊jquery validate的自定義驗證。

jquery validate有一個方法,可以讓用戶來自定義驗證規(guī)則。

案例一:

復(fù)制代碼 代碼如下:

//自定義驗證
            $.validator.addMethod("isPositive",function(value,element){
                var score = /^[0-9]*$/;
                return this.optional(element) || (score.test(value));
            },"<font color='#E47068'>請輸入大于0的數(shù)字</font>");

通過addMethod用戶可以自定義自己的驗證規(guī)則

這個方法有三個參數(shù),第一個參數(shù)表示驗證規(guī)則名稱,這里是isPositive,表示是否為正數(shù)。

第二個參數(shù)是真正的驗證主體,它是一個函數(shù),函數(shù)的第一個value表示調(diào)用這個驗證規(guī)則的表單的值,第二個element可以用來判斷是否為空,為空的時候,就不調(diào)用這個驗證規(guī)則了。

第三個參數(shù)是返回的錯誤提示。

具體如何使用呢?

其實跟jquery validate固有的驗證規(guī)則使用是一樣的。

復(fù)制代碼 代碼如下:

 <tr bgcolor="#f7f7f7"  height="43" align="right">
                        <td class="font14_s pdr_12 grey_70">總分:</td>
                        <td class="font14_s pl40" align="left"><input type="text" id="fullscore" name="fullscore" style=" margin-left: 10px; margin-right: 2px;" value="<!--{$aExams.fullscore}-->" class="required number isPositive input_233" /></td>
                    </tr>

如上所示,加粗的地方就是使用的方法,一共用了三個驗證規(guī)則,一個是必須,一個是數(shù)字,一個是自定義驗證規(guī)則。

效果圖如下:

案例二:

表單提交時,經(jīng)常會需要對日期進行驗證,比如結(jié)束時間必須大于開始時間。

這個時候可以通過jquery validate 自定義一個驗證方法,進行驗證。

方法如下:

復(fù)制代碼 代碼如下:

$.validator.addMethod("compareDate",function(value,element){
                var assigntime = $("#assigntime").val();
                var deadlinetime = $("#deadlinetime").val();
                var reg = new RegExp('-','g');
                assigntime = assigntime.replace(reg,'/');//正則替換
                deadlinetime = deadlinetime.replace(reg,'/');
                assigntime = new Date(parseInt(Date.parse(assigntime),10));
                deadlinetime = new Date(parseInt(Date.parse(deadlinetime),10));
                if(assigntime>deadlinetime){
                    return false;
                }else{
                    return true;
                }
            },"<font color='#E47068'>結(jié)束日期必須大于開始日期</font>");

上述代碼紅色部分是對時間字符串進行處理,處理成2013/12/12 08:09:00這種標準格式,

在處理的時候要用到replace的方法,這個方法最后結(jié)合正則表達式進行使用,也就是第一行的reg對象。

替換完了之后,如果比較時間呢?要進行三個處理,

1.將標準時間轉(zhuǎn)化為時間戳通過Date.parse()方法來處理。

2.將時間戳轉(zhuǎn)化為整數(shù),確保萬一,通過parseInt("",10)來處理。

3.將時間戳轉(zhuǎn)為日期對象new Date()。

轉(zhuǎn)為對象之后,就能夠比較時間大小了,直接判斷,如果結(jié)束時間小于開始時間,就進行錯誤提示。

這個時候compareDate就可以像其他的jquery validate驗證規(guī)則一樣驗證了。

案例三:ajax驗證

去數(shù)據(jù)庫驗證用戶名是否存在,這個也會經(jīng)常用到。

復(fù)制代碼 代碼如下:

$.validator.addMethod("checkUserExist",function(value,element){
                var user = value;
                $.ajax({
                    type:"POST",
                    async:false,
                    url:"/default/index/ajax/do/ajaxcheckuser",
                    data:"nick="+user,
                    success:function(response){
                        if(response){
                            res = false;
                        }else{
                            res = true;
                        }
                    }
                });
                return res;
            },"<font color='#E47068'>用戶名已存在</font>");

后臺驗證代碼:
復(fù)制代碼 代碼如下:

case 'ajaxcheckuser':
                $nick = trim($this->_getParam('nick'));
                if(isset($nick)){
                    $where['lx_user.nick = ?'] = array('type'=>1,'val'=>$nick);
                    $aUser = $daoUser->getUser($where);
                    if(count($aUser)>=1){
                        echo TRUE;
                    }else{
                        echo FALSE;
                    }
                }else{
                    echo FALSE;
                }
                break;

如果數(shù)據(jù)庫中存在,就返回true。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 老河口市| 增城市| 遂川县| 富蕴县| 布尔津县| 武陟县| 安国市| 澄迈县| 乌拉特前旗| 乐山市| 周至县| 山西省| 江西省| 邵阳市| 舟山市| 临汾市| 乌兰察布市| 安福县| 开阳县| 鄢陵县| 宜良县| 德安县| 游戏| 郯城县| 个旧市| 积石山| 沾化县| 剑阁县| 吐鲁番市| 台安县| 乌鲁木齐市| 邵阳县| 阜新| 阿拉善盟| 东宁县| 施甸县| 历史| 泽州县| 许昌县| 蒲城县| 富川|