通过 jQuery 验证日期字符串格式的最佳方法

Best way to validate date string format via jQuery

本文关键字:最佳 方法 格式 字符串 jQuery 验证 日期 通过      更新时间:2023-09-26

我找到了很多链接来验证字符串是否是日期。

就像这里和这里。

但无论如何,我无法弄清楚如何验证我们是否有这个东西:

6

/6/2012 其中前 6 是月,后 6 是

如果用户像这样输入它:

2012/6/6

任何线索如何以正确的方式完成?

谢谢!!

在这里,这应该适用于任何带有 4 位年份和任何分隔符的日期格式。我从我的插件中提取了它 理想形式 验证日期等等。

var isValidDate = function (value, userFormat) {
  var
  userFormat = userFormat || 'mm/dd/yyyy', // default format
  delimiter = /[^mdy]/.exec(userFormat)[0],
  theFormat = userFormat.split(delimiter),
  theDate = value.split(delimiter),
  isDate = function (date, format) {
    var m, d, y
    for (var i = 0, len = format.length; i < len; i++) {
      if (/m/.test(format[i])) m = date[i]
      if (/d/.test(format[i])) d = date[i]
      if (/y/.test(format[i])) y = date[i]
    }
    return (
      m > 0 && m < 13 &&
      y && y.length === 4 &&
      d > 0 && d <= (new Date(y, m, 0)).getDate()
    )
  }
  return isDate(theDate, theFormat)
}

使用正则表达式。

var dateRegEx = /^(0[1-9]|1[012]|[1-9])[- /.](0[1-9]|[12][0-9]|3[01]|[1-9])[- /.](19|20)'d'd$/
console.log("06/06/2012".match(dateRegEx) !== null) // true
console.log("6/6/2012".match(dateRegEx) !== null) // true
console.log("6/30/2012".match(dateRegEx) !== null) // true
console.log("30/06/2012".match(dateRegEx) !== null) // false

了解正则表达式。

编辑 - 免责声明

正如@elclanrs指出的那样,这仅验证字符串的格式,而不是实际日期,这意味着像 2 月 31 日这样的日期会过去。 但是,由于 OP 只要求"验证日期字符串格式",因此我将在此处保留此答案,因为对于某些人来说,这可能是您所需要的。

需要注意的是,OP 使用的 jQuery 验证插件也只验证格式。

最后,对于那些想知道的人,如果您需要验证日期,而不仅仅是格式,这个正则表达式在 (1-12)/(1-31)/(1900-2099) 日期字符串的域上的失败率为 ~2%。 请不要在 JPL 的关键任务代码中使用它。