jQuery 验证引擎:更改日期格式

jQuery Validation Engine : Change Date Format

本文关键字:日期 格式 验证 引擎 jQuery      更新时间:2023-09-26

My Datepicker code

$(function(){ 
         $( "#task_start_date").datepicker({
         dateFormat: 'dd-M-yy',
         showOn: 'button',
         buttonImage :image_us,
         buttonImageOnly: true
        });
});

网页输入:

<input type="text" class="form-control validate[required,custom[date]]" name="task_start_date" id="task_start_date" />

用于正确日期输入验证的 JS 函数:

"date": {                    
                    //  Check if date is valid by leap year
            "func": function (field) {
                    var pattern = new RegExp(/^('d{4})['/'-'.](0?[1-9]|1[012])['/'-'.](0?[1-9]|[12][0-9]|3[01])$/);
                    var match = pattern.exec(field.val());
                    if (match == null)
                       return false;
                    var year = match[1];
                    var month = match[2]*1;
                    var day = match[3]*1;                   
                    var date = new Date(year, month - 1, day); // because months starts from 0.
                    return (date.getFullYear() == year && date.getMonth() == (month - 1) && date.getDate() == day);
                },                      
             "alertText": "* Invalid date, must be in YYYY-MM-DD format"
                },

在这里,regex期望YYYY-MM-DD (2014-11-26)格式,但我们使用的是dd-M-yy(01-MAR-12)格式。

正则表达式尝试过:

/^(0?[1-9]|[12][0-9]|3[01])['/'-](0?[1-9]|1[012])['/'-]'d{4}$/

上述regex不起作用。如何更改regex以匹配预期的日期选取器输出。在数据库中插入的值是01-MAR-12的,而不是2014-11-26的。

谢谢。

^(0?[1-9]|[12][0-9]|3[01])[-][A-Z]{3}[-]''d{2}$

这应该可以解决问题。您尝试的正则表达式适用于 dd/mm/yyyy 或 dd-mm-yyyy 的格式。

试试这个(未测试):

(?:0[1-9]|1[0-9]|2[0-9]|3[01])-(?:JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC)-'d{2}
  • (?:0[1-9]|1[0-9]|2[0-9]|3[01]):比赛01至09,10至19,20至29,30至31。但是 Feb 没有超过 29 的任何东西,所以你如何处理我们不是基于正则表达式的
  • -:匹配连字符
  • (?:JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC) : 比赛月份
  • -:匹配连字符
  • -'d{2}:按任意顺序匹配任意两位数字

您可以缩小正则表达式,但我现在没有时间。

使用这个

"date": {                    
  //	Check if date is valid by leap year
  "func": function (field) {
  var pattern = new RegExp(/^(0?[1-9]|[12][0-9]|3[01])['/'-'.](0?[1-9]|1[012])['/'-'.]('d{4})$/);
	var match = pattern.exec(field.val());
	if (match == null)
	   return false;                     
	var year = match[3];
	var month = match[2]*1;
	var day = match[1]*1;					
	var date = new Date(year, month - 1, day); // because months starts from 0.
  return (date.getFullYear() == year && date.getMonth() == (month - 1) && date.getDate() == day);
  },                		
  "alertText": "* Invalid date, must be in dd-mm-yyyy format"
},