1.格式化时间

function GetDateTimeFormatter(value) {
        if (value == undefined) {
            return "";
        }
        /*json格式时间转js时间格式*/
        value = value.substr(1, value.length - 2);
        var obj = eval('(' + "{Date: new " + value + "}" + ')');
        var dateValue = obj["Date"];
        if (dateValue.getFullYear() < 1900) {
            return "";
        }

return dateValue.format("yyyy-mm-dd HH:MM:ss");
    }

2.获取当前时间

function GetCurTime() {
        var d = new Date();
        var years = d.getFullYear();
        var month = add_zero(d.getMonth() + 1);
        var days = add_zero(d.getDate());
        var hours = add_zero(d.getHours());
        var minutes = add_zero(d.getMinutes());
        var seconds = add_zero(d.getSeconds());
        var ndate = years + "-" + month + "-" + days + "- " + hours + ":" + minutes + ":" + seconds;
        return ndate;
    }
    function add_zero(temp) {
        if (temp < 10) return "0" + temp;
        else return temp;
    }

3.时间比较

eg . var a = GetDateTimeFormatter(t1);

var b =GetCurTime();

if(a>b){}//这样即可

4.ie下时间兼容问题

js时间推荐格式:2000/01/01

如使用2000-01-01在ie8及以下版本,存在兼容性问题

  1. var dateValue = "2013-01-01 01:01:00";
  2. var createDT = new Date(); //创建时间
  3. createDT.setFullYear(dateValue.substr(0, 4));
  4. createDT.setMonth(dateValue.substr(5, 2) - 1);
  5. createDT.setDate(dateValue.substr(8, 2));
  6. createDT.setHours(dateValue.substr(11, 2));
  7. createDT.setMinutes(dateValue.substr(14, 2));
  8. createDT.setSeconds(0);
  1. /**
  2. * 解析输入的dateStr,返回Date类型。
  3. * dateStr: XXXX-XX-XX
  4. */
  5. function parseDate(dateStr){
  6. var strArray = dateStr.split("-");
  7. if(strArray.length == 3){
  8. return new Date(strArray[0], strArray[1], strArray[2]);
  9. }else{
  10. return new Date();
  11. }
  12. }

5.Date方法扩展

  1. /*
  2. 函数:日期 加n天
  3. 参数:n是天数
  4. 返回:n天后的日期
  5. */
  6. Date.prototype.addDays = Date.prototype.addDays || function (n) {
  7. this.setDate(this.getDate() + n);
  8. return this;
  9. }
  10. /*
  11. 函数:日期 减n天
  12. 参数:n是天数
  13. 返回:n天后的日期
  14. */
  15. Date.prototype.minusDays = Date.prototype.minusDays || function (n) {
  16. this.setDate(this.getDate() - n);
  17. return this;
  18. }
  19. /*
  20. 函数:日期 加n天
  21. 参数:n是天数
  22. 返回:n天后的日期
  23. */
  24. Date.prototype.getWeek = Date.prototype.getWeek || function (date) {
  25. // var n = date.getDay();
  26. var n = this.getDay();
  27. var rtnStr = "";
  28. switch (n) {
  29. case 0: { rtnStr = "星期日"; break; }
  30. case 1: { rtnStr = "星期一"; break; }
  31. case 2: { rtnStr = "星期二"; break; }
  32. case 3: { rtnStr = "星期三"; break; }
  33. case 4: { rtnStr = "星期四"; break; }
  34. case 5: { rtnStr = "星期五"; break; }
  35. case 6: { rtnStr = "星期六"; break; }
  36. default: { rtnStr = ""; break; }
  37. }
  38. return rtnStr;
  39. }
  40. /*
  41. 函数:把字符串转换为日期对象
  42. 参数:yyyy-mm-dd或yyyy/mm/dd形式的字符串
  43. 返回:Date对象
  44. 注:IE下不支持直接实例化日期对象,如new Date("2011-04-06")
  45. */
  46. Date.prototype.convertDate = function (date) {
  47. var flag = true;
  48.  
  49. var dateArray = date.split("-");
  50. if (dateArray.length != 3) {
  51. dateArray = date.split("/");
  52. if (dateArray.length != 3) {
  53. return null;
  54. }
  55. // flag = false;
  56. }
  57. var newDate = new Date();
  58. if (flag) {
  59. // month从0开始
  60. newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);
  61. }
  62. else {
  63. newDate.setFullYear(dateArray[2], dateArray[1] - 1, dateArray[0]);
  64. }
  65. newDate.setHours(0, 0, 0);
  66. return newDate;
  67. };
  68.  
  69. /*
  70. 函数:计算两个日期之间的差值
  71. 参数:date是日期对象
  72. flag:ms-毫秒,s-秒,m-分,h-小时,d-天,M-月,y-年
  73. 返回:当前日期和date两个日期相差的毫秒/秒/分/小时/天
  74. */
  75. Date.prototype.dateDiff = function (date, flag) {
  76. var msCount = 24 * 60 * 60 * 1000;
  77. this.setHours(0, 0, 0, 0);
  78. date.setHours(0, 0, 0, 0);
  79. var diff = this.getTime() - date.getTime();
  80. return Math.floor(diff / msCount);
  81.  
  82. switch (flag) {
  83. case "ms":
  84. msCount = 1;
  85. break;
  86. case "s":
  87. msCount = 1000;
  88. break;
  89. case "m":
  90. msCount = 60 * 1000;
  91. break;
  92. case "h":
  93. msCount = 60 * 60 * 1000;
  94. break;
  95. case "d":
  96. msCount = 24 * 60 * 60 * 1000;
  97. break;
  98. }
  99. return Math.floor(diff / msCount);
  100. };
  101.  
  102. /*
  103. 函数:格式化日期
  104. 参数:formatStr-格式化字符串
  105. d:将日显示为不带前导零的数字,如1
  106. dd:将日显示为带前导零的数字,如01
  107. ddd:将日显示为缩写形式,如Sun
  108. dddd:将日显示为全名,如Sunday
  109. M:将月份显示为不带前导零的数字,如一月显示为1
  110. MM:将月份显示为带前导零的数字,如01
  111. MMM:将月份显示为缩写形式,如Jan
  112. MMMM:将月份显示为完整月份名,如January
  113. yy:以两位数字格式显示年份
  114. yyyy:以四位数字格式显示年份
  115. h:使用12小时制将小时显示为不带前导零的数字,注意||的用法
  116. hh:使用12小时制将小时显示为带前导零的数字
  117. H:使用24小时制将小时显示为不带前导零的数字
  118. HH:使用24小时制将小时显示为带前导零的数字
  119. m:将分钟显示为不带前导零的数字
  120. mm:将分钟显示为带前导零的数字
  121. s:将秒显示为不带前导零的数字
  122. ss:将秒显示为带前导零的数字
  123. l:将毫秒显示为不带前导零的数字
  124. ll:将毫秒显示为带前导零的数字
  125. tt:显示am/pm
  126. TT:显示AM/PM
  127. 返回:格式化后的日期
  128. */
  129. Date.prototype.format = function (formatStr) {
  130. var date = this;
  131.  
  132. /*
  133. 函数:填充0字符
  134. 参数:value-需要填充的字符串, length-总长度
  135. 返回:填充后的字符串
  136. */
  137. var zeroize = function (value, length) {
  138. if (!length) {
  139. length = 2;
  140. }
  141. value = new String(value);
  142. for (var i = 0, zeros = ''; i < (length - value.length) ; i++) {
  143. zeros += '0';
  144. }
  145. return zeros + value;
  146. };
  147.  
  148. return formatStr.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|M{1,4}|yy(?:yy)?|([hHmstT])\1?|[lLZ])\b/g, function ($0) {
  149. switch ($0) {
  150. case 'd': return date.getDate();
  151. case 'dd': return zeroize(date.getDate());
  152. case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][date.getDay()];
  153. case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][date.getDay()];
  154. case 'M': return date.getMonth() + 1;
  155. case 'MM': return zeroize(date.getMonth() + 1);
  156. case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][date.getMonth()];
  157. case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][date.getMonth()];
  158. case 'yy': return new String(date.getFullYear()).substr(2);
  159. case 'yyyy': return date.getFullYear();
  160. case 'h': return date.getHours() % 12 || 12;
  161. case 'hh': return zeroize(date.getHours() % 12 || 12);
  162. case 'H': return date.getHours();
  163. case 'HH': return zeroize(date.getHours());
  164. case 'm': return date.getMinutes();
  165. case 'mm': return zeroize(date.getMinutes());
  166. case 's': return date.getSeconds();
  167. case 'ss': return zeroize(date.getSeconds());
  168. case 'l': return date.getMilliseconds();
  169. case 'll': return zeroize(date.getMilliseconds());
  170. case 'tt': return date.getHours() < 12 ? 'am' : 'pm';
  171. case 'TT': return date.getHours() < 12 ? 'AM' : 'PM';
  172. }
  173. });
  174. }

6.时间戳

  1. 获取当前时间戳:
  2. 第一种方法:
  3.  
  4. var timestamp = Date.parse(new Date());
  5. 结果:1280977330000
  6. 第二种方法:
  7.  
  8. var timestamp = (new Date()).valueOf();
  9. 结果:1280977330748
  10.  
  11. 第三种方法:
  12.  
  13. var timestamp=(new Date()).getTime();
  14. 结果:1280977330748
  15.  
  16. 第一种:获取的时间戳是把毫秒改成000显示,
  17.  
  18. 第二种和第三种是获取了当前毫秒的时间戳。

有时遇到返回的时间格式是json字符串,转成时间戳:

parseInt((dateJsonStr).replace("/Date(", "").replace(")/", ""), 10);

js 时间处理的更多相关文章

  1. js 时间构造函数

    js 时间构造函数,js中没有类似ToString("yyyy-mm-dd HH:mm:ss") 的方法,但是可以用下面的方式来初始化 var cdate = new Date(& ...

  2. js时间倒计时

    看了网上的其他的例子,觉得写的都有点复杂,不好理解,于是自己动手写了个. 本来想封装成jquery插件,但是觉得因为功能很简单,没有必要做成jquery插件,引用的时候不需要引入jqery库,这里直接 ...

  3. Js 时间与字符串转示例

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  4. js获取当前时间,js时间函数

    Js获取当前日期时间及其它操作,js时间函数 var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); ...

  5. js 时间函数 及相关运算大全

    js 时间函数 及相关运算大全 var myDate = new Date(); myDate.getYear();        //获取当前年份(2位) myDate.getFullYear(); ...

  6. js时间过滤方法

    js时间过滤  自己写的  记录一下 /** * * 过滤时间格式 * Created by Catlina at 2019.4.26 */ export const setTime = time = ...

  7. js 时间类函数

    js 时间类是  Date() var currtime = new Date();// 实例一个时间,是当前时间 接收一个时间戳为参数 var time2=new Date(currtime.get ...

  8. js 时间格式化 (兼容safari)

    js 时间格式化,兼容IE8和safari浏览器. function formatDate(date, fmt, near, type) { var dateStr = date; if (!date ...

  9. js时间格式化函数,支持Unix时间戳

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. ALV详解:OO ALV

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  2. ubuntu14.04换一个更快的源

    mirrors.yun-idc.com,这个源可比ubuntu自带的源快多了,我的source.list文件内容如下: deb http://mirrors.yun-idc.com/ubuntu/ t ...

  3. find command in linux terminal

    Say you want to search for files with keyword as "keyword". find / -name keyword 2> /de ...

  4. 解决iOS内存泄露

    文章很好,摘自:http://www.codeceo.com/article/xcode-instruments-ios-memory.html 虽然iOS 5.0版本之后加入了ARC机制,由于相互引 ...

  5. JAX-WS:背后的技术JAXB及传递Map

    转载:http://www.programgo.com/article/98912703200/ 1.什么是JAX-WS JAX-WS (JavaTM API for XML-Based Web Se ...

  6. ubuntu12.04_命令

    1. 切换 终端方式 与 图形界面方式: 切换到 终端方式:ctrl+alt+F1~F6(貌似有时 alt+F1~F6也行?) 切换回 图形界面方式:ctrl+alt+F7 2. ubuntu12.0 ...

  7. 子div用了float浮动之后,如何撑开父元素,让父元素div自动适应高度的问题

    方法一: html: <div id="all1"> <div id="left1">1</div> <div id= ...

  8. Git基本交互流程图

  9. Android网络编程系列 一 TCP/IP协议族之网际层

    这篇借鉴的文章主要是用于后续文章知识点的扩散,在此特作备份和扩散学习交流. 网际层包括:IP.ICMP.IGMP 以及处在网际层实际工作在链路层的 ARP 和 RARP等等协议. 1.IP协议 互联网 ...

  10. ID和Name的区别

    HTML元素的ID和Name属性的区别一直认为ID和NAME是一样的,两个又可以一起出现,甚是疑惑.今天BAIDU了一下,才发现里面大有文章.发出来研究研究:最classical的答案:ID就像是一个 ...