文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript中有哪些时间处理函数

2024-04-02 19:55

关注

这篇文章将为大家详细讲解有关JavaScript中有哪些时间处理函数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、把字符串转换为日期对象

有时需要把字符串转换为日期对象,但是IE下不支持new Date(“2011-04-07”)这样实例化日期对象,ff下支持,所以写了一个扩展函数,用来把形如yyyy-mm-dd或者dd/mm/yyyy的字符串转换为日期对象。代码如下:

   Date.prototype.convertDate = function (date) {   var flag = true;   var dateArray = date.split("-");  if (dateArray.length != 3) {  dateArray = date.split("/");  if (dateArray.length != 3) {  return null;  }  flag = false;  }  var newDate = new Date();  if (flag) {  // month从0开始  newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);  }  else {  newDate.setFullYear(dateArray[2], dateArray[1] - 1, dateArray[0]);  }  newDate.setHours(0, 0, 0);  return newDate;  };

测试:

<script type="text/javascript">  document.writeln(new Date().convertDate("7/12/2011"));  </script>

输出:

Wed Dec 07 2011 17:30:58 GMT+0800

二、计算两个日期之间的差值

这个函数可以计算两个日期之前的差值(毫秒/秒/分/小时/天),主要用到了getTime()函数和Math.floor()函数,代码如下:

   Date.prototype.dateDiff = function (date, flag) {   var msCount;   var diff = this.getTime() - date.getTime();  switch (flag) {  case "ms":  msCount = 1;  break;  case "s":  msCount = 1000;  break;  case "m":  msCount = 60 * 1000;  break;  case "h":  msCount = 60 * 60 * 1000;  break;  case "d":  msCount = 24 * 60 * 60 * 1000;  break;  }  return Math.floor(diff / msCount);  };

测试:

<script type="text/javascript">  var d1 = new Date().convertDate("2011-04-08");  var d2 = new Date().convertDate("2011-04-07");  document.writeln(d1.dateDiff(d2, 'd'));  </script>

结果:

1

三、判断一个年份是否为闰年

代码:

  Date.prototype.isLeapYear = function () {  var year = this.getFullYear();  return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);  }

测试:

<script type="text/javascript">  document.writeln(new Date().convertDate("2000-04-08").isLeapYear() + "<br />");  document.writeln(new Date().convertDate("2011-04-08").isLeapYear() + "<br />");  </script>

结果:

true

false

四、格式化日期

这个函数是从网上搜来的,稍微修改了一下,它类似.net中Format函数,传入格式化字符串如”yyyy-MM-dd”,返回格式化后的日期。

 Date.prototype.format = function (formatStr) {  var date = this;   var zeroize = function (value, length) {  if (!length) {  length = 2;  }  value = new String(value);  for (var i = 0, zeros = ''; i < (length - value.length); i++) {  zeros += '0';  }  return zeros + value;  };  return formatStr.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|M{1,4}|yy(?:yy)?|([hHmstT])\1?|[lLZ])\b/g, function($0) {  switch ($0) {  case 'd': return date.getDate();  case 'dd': return zeroize(date.getDate());  case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][date.getDay()];  case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][date.getDay()];  case 'M': return date.getMonth() + 1;  case 'MM': return zeroize(date.getMonth() + 1);  case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][date.getMonth()];  case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][date.getMonth()];  case 'yy': return new String(date.getFullYear()).substr(2);  case 'yyyy': return date.getFullYear();  case 'h': return date.getHours() % 12 || 12;  case 'hh': return zeroize(date.getHours() % 12 || 12);  case 'H': return date.getHours();  case 'HH': return zeroize(date.getHours());  case 'm': return date.getMinutes();  case 'mm': return zeroize(date.getMinutes());  case 's': return date.getSeconds();  case 'ss': return zeroize(date.getSeconds());  case 'l': return date.getMilliseconds();  case 'll': return zeroize(date.getMilliseconds());  case 'tt': return date.getHours() < 12 ? 'am' : 'pm';  case 'TT': return date.getHours() < 12 ? 'AM' : 'PM';  }  });  }

测试:

<script type="text/javascript">  document.writeln(new Date().format("yyyy-MM-dd hh:mm:ss"));  </script>

结果:

2011-04-08 10:13:37

关于JavaScript中有哪些时间处理函数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯