格式化用户输入日期。

时间:2012-06-21 16:51:25

标签: javascript jquery date

是否有更好的方法来格式化用户估算的日期。我有一个输入字段,当点击日历弹出时,您可以选择日期,但用户也可以选择输入日期。我希望用户能够键入1/12和我的javascript格式化为2012年12月12日。有没有一种简单的方法可以解决这个问题而不必进行各种类型的检查?如果不是最好的方法是什么?

3 个答案:

答案 0 :(得分:3)

此库可以帮助您:http://www.datejs.com/

dd / mm / yyyy是有效的格式,例如在西班牙,英国,...

答案 1 :(得分:3)

我刚试了一下,但不确定这是不是正确的方法,但我认为它有效(月/日/年)。

$('input[name="txt_date"]').on('blur', function(e){
    var dt=$(this).val();
    if(dt!='')
    {
        if(dt.indexOf('/'))
        {
            var da=dt.split('/');
            var l=da.length;
            if(l <= 3)
            {
                var date='';
                for(i=0;i<l;i++)
                {
                   if(i==0)
                   {
                      if(da[i].match(/^\d{1}|d{2}$/) && da[i]>0 && da[i]<=12)
                      {
                          var m=da[i].length==1 ? '0'+da[i] : da[i];
                          date=m;
                      }
                   }
                   if(i==1)
                   {
                       if(da[i].match(/^\d{1}|d{2}$/) && da[i]>0 && da[i]<=31)
                       {
                           var d=da[i].length==1 ? '0'+da[i] : da[i];
                           date+='/'+d;
                       }
                   }
                   if(i==2)
                   {
                       if(da[i].match(/^\d{4}$/))
                       {
                           date+='/'+da[i];
                       }
                       else date+='/'+new Date().getFullYear();
                   }
                }
                if(l<3)
                {
                    date+='/'+new Date().getFullYear();
                }
                if(date.match(/^\d{2}\/\d{2}\/\d{4}$/))
                {
                    $(this).val(date);
                }
                else alert('invalid date!');
            }
        }
    }
});

DEMO.

答案 2 :(得分:1)

这就是我想出来的。

var checkDate = function(dateVal, input){

            if(dateVal.length == 10){
                return;
            }
            var d = new Date();
            var currentMonth = d.getMonth();
            var year = d.getFullYear();
            var firstIndex = dateVal.indexOf('/');
            var month = parseInt(dateVal.substr(0, firstIndex));
            var day = parseInt(dateVal.substr(firstIndex + 1, 2));

            if(month < 10){
                month = '0' + month;
            }

            if(day < 10){
                day = '0' + day;
            }

            if(month > currentMonth){
                year = year - 1;
            }

            dateVal = month + '/' + day + '/' + year;

            if(isNaN(month)){
                input.val('');
                return;
            }
            input.val(dateVal);

        };