中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 表單驗證中時間起止判斷的遞歸處理
Zen Coding:快速編寫HTML/CSS代碼 回到列表 JavaScript對象探討
 表單驗證中時間起止判斷的遞歸處理

作者:dishuipiaoxiang 時間: 2009-12-15 文檔類型:原創(chuàng) 來自:藍色理想

表單驗證中時間起止判斷的遞歸處理

在最近一個項目中,表單驗證需要對時間的起止范圍進行判斷:結(jié)束時間需大于或等于開始時間。即:結(jié)束年須大于起始年;如果相等,則比較起始月與結(jié)束月;如果起止月也相等,則比較日期。那么,對于每一次驗證,可以用下面這個函數(shù)來進行比較。

function compare(begin,end,error){
    var begin = parseInt(begin,10);
    var end = parseInt(end,10);
    var diff = end - begin;
    if(diff < 0){
        alert(error);
    }else{
        return true;
    }
}

這樣,在驗證的時候,只要結(jié)果返回真就表示通過。如:

var year = compare(2001,2003,'年');
var month = compare(1,2,'月');
var day = compare(12,13,'天');
alert(year && month && day); //結(jié)果為真------"true"

將上面的起止月份和起止日期修改一下。如:

var year = compare(2001,2003,'年');
var month = compare(3,2,'月');
var day = compare(24,13,'天');
alert(year && month && day); /結(jié)果為假------"false"

執(zhí)行結(jié)果,依次顯示”月”,”天”,”false”;實際上,當起止月份不正確的時候,我們沒必要對日期進行驗證;月份驗證的前提條件是年驗證通過;天驗證的前提是月份驗證通過。仔細分析之后,我決定將上面函數(shù)的三個參數(shù)用單體模式存儲起來,即:

{
    begin:2001,
    end:2003,
    error:"結(jié)束年限須大于起始年限"
}

但是,我又不想定義函數(shù)的參數(shù),函數(shù)能否根據(jù)傳遞的參數(shù)自動進行驗證了?答案是肯定的。在函數(shù)的開始,先判斷參數(shù)的個數(shù),如果大于1,則含有遞歸處理。如何做到遞歸處理呢?我在函數(shù)內(nèi)部作了如下處理:

var len = arguments.length;
if(len > 1){
    var args = Array.prototype.slice.call(arguments);
    args.shift(); //將第一個參數(shù)移除,余下的用作遞歸處理的參數(shù)
}

對于arguments,我們不能直接調(diào)用Array.shift()方法。雖然 arguments有l(wèi)ength屬性,但畢竟不是數(shù)組,所以用Array.slice()方法將其轉(zhuǎn)換成數(shù)組。關于arguments,在網(wǎng)上可以了解到更多的信息,這里不在贅述。為什么只有在len大于1時才進行處理呢?因為參數(shù)為1時,就不需要進行下一步驗證了。遞歸處理在什么時候進行呢?仔細想想,只有在初始值與結(jié)束值相等時才需要,明白了這些,我們就很容易構(gòu)建我們的驗證函數(shù)了。

var diff = parseInt(arguments[0].end,10) - parseInt(arguments[0].begin,10);
if(diff <0 ){
    alert(arguments[0].error);
    return false;
}else if(diff == 0){
    return len > 1 ? arguments.callee.apply(this,args) : true;
}else{
    return true;
}

上面的代碼中,arguments.callee是函數(shù)自身,關于apply的用法可以在web查找相關資料。

function compare(){
    var len = arguments.length;
    if(len > 1){
        var args = Array.prototype.slice.call(arguments);
        args.shift(); //將第一個參數(shù)移除,余下的用作遞歸處理的參數(shù)

    }
    var diff = parseInt(arguments[0].end,10) - parseInt(arguments[0].begin,10);
    if(diff <0 ){
        alert(arguments[0].error);
        return false;
    }else if(diff == 0){
        return len > 1 ? arguments.callee.apply(this,args) : true;
    }else{
        return true;
    }
}

到此驗證函數(shù)已經(jīng)完成,但需要注意的是:

  1. 雖然沒有確定參數(shù)的個數(shù),但參數(shù)的順序還是重要的,因為前一個參數(shù)的驗證結(jié)果決定了下一個參數(shù)的驗證是否繼續(xù);
  2. parseInt()函數(shù)的第二個參數(shù)10不要忽略。如果忽略,當遇到以0開始的數(shù)值(如07、08)時將會按八進制進行處理。

到此已經(jīng)結(jié)束,看看 示例 。有時候,我們不想以alert的方式顯示錯誤信息,我們可以自定義處理函數(shù)將其作為最后一個參數(shù)傳入其中。那么在函數(shù)的開始,取得處理函數(shù),如:

var func = arguments[len - 1];
if(typeof  func  ==  'function'){
func(arguments[0]);
}

所以,最終的處理函數(shù)是這樣的:

function compare(){
    var len = arguments.length;
    var func = arguments[len - 1];
    if(len > 1){
        var args = Array.prototype.slice.call(arguments);
        args.shift(); //將第一個參數(shù)移除,余下的用作遞歸處理的參數(shù)
    }
    var diff = parseInt(arguments[0].end,10) - parseInt(arguments[0].begin,10);
    if(diff <0 ){
        (typeof  func  ==  'function') ? func(arguments[0].error) : alert(arguments[0].error);
        return false;
    }else if(diff == 0){
        return len > 1 ? arguments.callee.apply(this,args) : true;
    }else{
        return true;
    }
}

原文:http://www.denisdeng.com/?p=631

本文鏈接:http://www.95time.cn/tech/web/2009/7270.asp 

出處:藍色理想
責任編輯:bluehearts

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

作者文章 更多作者文章
用css實現(xiàn)透視效果
日期垂直排列的兩種技巧
Javascript函數(shù)類型判斷解決方案
解讀javascript的計時器 II
解讀javascript的計時器 I
關鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2