[jQuery UI datepicker] 不正な日付を修正する方法

システムによっては月日が二桁を想定しているものもあるかと思います。
例えば 2012 年 2 月 18 日は「2012/2/18」ではなく「2012/02/18」とか。

(サーバサイドで直してやってもいいんですが、画面の方で修正した方がユーザーには分かりやすいかもしれないし…という事で)

datepicker が閉じられた時に(onClose)、入力された日付を精査します。
精査の内容は以下の通りです。

  • 西暦が4以上は今年の西暦をセットする(10000年とか)
  • 月・日のゼロパディング
  • 0月や0日が入力された場合は今月の月日をセットする
<script type="text/javascript">
$(function() {
    // 本日の日付
    var nowdate = new Date();
    var year = nowdate.getFullYear();
    var mon  = nowdate.getMonth() + 1;
    var day  = nowdate.getDate();

$(&quot;#datepicker&quot;).datepicker({
    onClose : function(selectedDate) {
        if(selectedDate!=&quot;&quot;){
            var dpckr = selectedDate.split(&quot;/&quot;);
            var fmYY  = dpckr[0]; // year
            var fmMM  = dpckr[1]; // month
            var fmDD  = dpckr[2]; // day

            // 空なら0入れておく
            if(fmYY==&quot;&quot; || fmYY==null){ fmYY = 0; }
            if(fmMM==&quot;&quot; || fmMM==null){ fmMM = 0; }
            if(fmDD==&quot;&quot; || fmDD==null){ fmDD = 0; }
            // 西暦が4桁以上の場合は今年をセット
            if (fmYY.length &gt; 4){ fmYY = year; }
            // ゼロパディング
            if (parseInt(fmMM, 10) &lt; 10) { fmMM = &quot;0&quot; + parseInt(fmMM, 10); }
            if (parseInt(fmDD, 10) &lt; 10) { fmDD = &quot;0&quot; + parseInt(fmDD, 10); }
            // 00の場合は今月、今日をセット
            if (fmMM == &quot;00&quot;) { fmMM = mon; }
            if (fmDD == &quot;00&quot;) { fmDD = day; }

            // セット
            $(this).val(fmYY + &quot;/&quot; + fmMM + &quot;/&quot; + fmDD);

        }
    }
});

});
</script>

もう少し綺麗な書き方があると思うのですが、
年末でめんどくさくなってこれでいいやってなりました。
(あまり複雑な状況は想定してないです。入力途中で日付や年が変わるだとか)

他の datapicker にも応用は訊くかと思います。