JavaScript日期格式化与日期校验

JavaScript日期格式化与日期校验

// 日期校验
var validateDate = function (date) {
  // 输出当前时间
  let today = dateFormat(new Date(), 'yyyy-MM-dd')
  if (date > today) {
    return false
  }
  var dates = date.split('-')
  // console.log(dates)
  if (dates.length === 3) {
    let intYear = parseInt(dates[0], 10)
    let intMonth = parseInt(dates[1], 10)
    let intDay = parseInt(dates[2], 10)
    if (isNaN(intYear) || isNaN(intMonth) || isNaN(intDay)) {
      return false
    }
    if (intYear > 2100 || intYear < 1900 || intMonth > 12 || intMonth < 0 || intDay > 31 || intDay < 0) {
      return false
    }
    if (intMonth < 1 || intDay < 1) {
      return false
    }
    if ((intMonth === 4 || intMonth === 6 || intMonth === 9 || intMonth === 11) && intDay > 30) {
      return false
    }
    if ((intYear % 100 === 0 && intYear % 400) || (intYear % 100 && intYear % 4 === 0)) {
      if (intDay > 29) { return false }
    } else {
      if (intDay > 28) { return false }
    }
    return true
  }
  return false
}

// 日期格式化
var dateFormat = function (date, fmt) {
  var o = {
    'M+': date.getMonth() + 1,
    'd+': date.getDate(),
    'h+': date.getHours(),
    'm+': date.getMinutes(),
    's+': date.getSeconds(),
    'q+': Math.floor((date.getMonth() + 3) / 3),
    'S': date.getMilliseconds()
  }
  if (/(y+)/.test(fmt)) {
    fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length))
  }
  for (var k in o) {
    if (new RegExp('(' + k + ')').test(fmt)) {
      fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))
    }
  }
  return fmt
}
上一篇 JS类型转换(强制和自动的规则)
下一篇 JS遍历对象、map及数组
目录
文章列表
1 React Native学习之ListView组件
React Native学习之ListView组件
2
Android内容被底部虚拟导航栏遮挡解决
Android内容被底部虚拟导航栏遮挡解决
3
Zuul动态路由源码及几种实现方式
Zuul动态路由源码及几种实现方式
4
Nexus 3.x配置deployment角色
Nexus 3.x配置deployment角色
5
Spring Boot中MongoDB的使用
Spring Boot中MongoDB的使用
最新评论
一位WordPress评论者
一位WordPress评论者
2月12日
您好,这是一条评论。若需要审核、编辑或删除评论,请访问仪表盘的评论界面。评论者头像来自 Gravatar。