`

js日期时间函数(经典+完善+实用)

阅读更多

日期时间脚本库方法列表

Date.prototype.isLeapYear 判断闰年
Date.prototype.Format 日期格式化
Date.prototype.DateAdd 日期计算
Date.prototype.DateDiff 比较日期差
Date.prototype.toString 日期转字符串
Date.prototype.toArray 日期分割为数组
Date.prototype.DatePart 取日期的部分信息
Date.prototype.MaxDayOfDate 取日期所在月的最大天数
Date.prototype.WeekNumOfYear 判断日期所在年的第几周
StringToDate 字符串转日期型
IsValidDate 验证日期有效性
CheckDateTime 完整日期时间检查
daysBetween 日期天数差

js 代码
 
  1. //---------------------------------------------------  
  2. // 判断闰年  
  3. //---------------------------------------------------  
  4. Date.prototype.isLeapYear = function()   
  5. {   
  6.     return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));   
  7. }   
  8.   
  9. //---------------------------------------------------  
  10. // 日期格式化  
  11. // 格式 YYYY/yyyy/YY/yy 表示年份  
  12. // MM/M 月份  
  13. // W/w 星期  
  14. // dd/DD/d/D 日期  
  15. // hh/HH/h/H 时间  
  16. // mm/m 分钟  
  17. // ss/SS/s/S 秒  
  18. //---------------------------------------------------  
  19. Date.prototype.Format = function(formatStr)   
  20. {   
  21.     var str = formatStr;   
  22.     var Week = ['日','一','二','三','四','五','六'];  
  23.   
  24.     str=str.replace(/yyyy|YYYY/,this.getFullYear());   
  25.     str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100));   
  26.   
  27.     str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0' + this.getMonth());   
  28.     str=str.replace(/M/g,this.getMonth());   
  29.   
  30.     str=str.replace(/w|W/g,Week[this.getDay()]);   
  31.   
  32.     str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate());   
  33.     str=str.replace(/d|D/g,this.getDate());   
  34.   
  35.     str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours());   
  36.     str=str.replace(/h|H/g,this.getHours());   
  37.     str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes());   
  38.     str=str.replace(/m/g,this.getMinutes());   
  39.   
  40.     str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds());   
  41.     str=str.replace(/s|S/g,this.getSeconds());   
  42.   
  43.     return str;   
  44. }   
  45.   
  46. //+---------------------------------------------------  
  47. //| 求两个时间的天数差 日期格式为 YYYY-MM-dd   
  48. //+---------------------------------------------------  
  49. function daysBetween(DateOne,DateTwo)  
  50. {   
  51.     var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-'));  
  52.     var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);  
  53.     var OneYear = DateOne.substring(0,DateOne.indexOf ('-'));  
  54.   
  55.     var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-'));  
  56.     var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);  
  57.     var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-'));  
  58.   
  59.     var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);   
  60.     return Math.abs(cha);  
  61. }  
  62.   
  63.   
  64. //+---------------------------------------------------  
  65. //| 日期计算  
  66. //+---------------------------------------------------  
  67. Date.prototype.DateAdd = function(strInterval, Number) {   
  68.     var dtTmp = this;  
  69.     switch (strInterval) {   
  70.         case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number));  
  71.         case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number));  
  72.         case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number));  
  73.         case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number));  
  74.         case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number));  
  75.         case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
  76.         case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
  77.         case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
  78.     }  
  79. }  
  80.   
  81. //+---------------------------------------------------  
  82. //| 比较日期差 dtEnd 格式为日期型或者 有效日期格式字符串  
  83. //+---------------------------------------------------  
  84. Date.prototype.DateDiff = function(strInterval, dtEnd) {   
  85.     var dtStart = this;  
  86.     if (typeof dtEnd == 'string' )//如果是字符串转换为日期型  
  87.     {   
  88.         dtEnd = StringToDate(dtEnd);  
  89.     }  
  90.     switch (strInterval) {   
  91.         case 's' :return parseInt((dtEnd - dtStart) / 1000);  
  92.         case 'n' :return parseInt((dtEnd - dtStart) / 60000);  
  93.         case 'h' :return parseInt((dtEnd - dtStart) / 3600000);  
  94.         case 'd' :return parseInt((dtEnd - dtStart) / 86400000);  
  95.         case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7));  
  96.         case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1);  
  97.         case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear();  
  98.     }  
  99. }  
  100.   
  101. //+---------------------------------------------------  
  102. //| 日期输出字符串,重载了系统的toString方法  
  103. //+---------------------------------------------------  
  104. Date.prototype.toString = function(showWeek)  
  105. {   
  106.     var myDate= this;  
  107.     var str = myDate.toLocaleDateString();  
  108.     if (showWeek)  
  109.     {   
  110.         var Week = ['日','一','二','三','四','五','六'];  
  111.         str += ' 星期' + Week[myDate.getDay()];  
  112.     }  
  113.     return str;  
  114. }  
  115.   
  116. //+---------------------------------------------------  
  117. //| 日期合法性验证  
  118. //| 格式为:YYYY-MM-DD或YYYY/MM/DD  
  119. //+---------------------------------------------------  
  120. function IsValidDate(DateStr)   
  121. {   
  122.     var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格;   
  123.     if(sDate==''return true;   
  124.     //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为''   
  125.     //数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式   
  126.     var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2 }[\-/]{ 1 }[\d]{ 1,2 }/g,'');   
  127.     if (s==''//说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D   
  128.     {   
  129.         var t=new Date(sDate.replace(/\-/g,'/'));   
  130.         var ar = sDate.split(/[-/:]/);   
  131.         if(ar[0] != t.getYear() || ar[1] != t.getMonth()+1 || ar[2] != t.getDate())   
  132.         {   
  133.             //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');   
  134.             return false;   
  135.         }   
  136.     }   
  137.     else   
  138.     {   
  139.         //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');   
  140.         return false;   
  141.     }   
  142.     return true;   
  143. }   
  144.   
  145. //+---------------------------------------------------  
  146. //| 日期时间检查  
  147. //| 格式为:YYYY-MM-DD HH:MM:SS  
  148. //+---------------------------------------------------  
  149. function CheckDateTime(str)  
  150. {   
  151.     var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2 }):(\d{ 1,2 }):(\d{ 1,2 })$/;   
  152.     var r = str.match(reg);   
  153.     if(r==null)return false;   
  154.     r[2]=r[2]-1;   
  155.     var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);   
  156.     if(d.getFullYear()!=r[1])return false;   
  157.     if(d.getMonth()!=r[2])return false;   
  158.     if(d.getDate()!=r[3])return false;   
  159.     if(d.getHours()!=r[4])return false;   
  160.     if(d.getMinutes()!=r[5])return false;   
  161.     if(d.getSeconds()!=r[6])return false;   
  162.     return true;   
  163. }   
  164.   
  165. //+---------------------------------------------------  
  166. //| 把日期分割成数组  
  167. //+---------------------------------------------------  
  168. Date.prototype.toArray = function()  
  169. {   
  170.     var myDate = this;  
  171.     var myArray = Array();  
  172.     myArray[0] = myDate.getFullYear();  
  173.     myArray[1] = myDate.getMonth();  
  174.     myArray[2] = myDate.getDate();  
  175.     myArray[3] = myDate.getHours();  
  176.     myArray[4] = myDate.getMinutes();  
  177.     myArray[5] = myDate.getSeconds();  
  178.     return myArray;  
  179. }  
  180.   
  181. //+---------------------------------------------------  
  182. //| 取得日期数据信息  
  183. //| 参数 interval 表示数据类型  
  184. //| y 年 m月 d日 w星期 ww周 h时 n分 s秒  
  185. //+---------------------------------------------------  
  186. Date.prototype.DatePart = function(interval)  
  187. {   
  188.     var myDate = this;  
  189.     var partStr='';  
  190.     var Week = ['日','一','二','三','四','五','六'];  
  191.     switch (interval)  
  192.     {   
  193.         case 'y' :partStr = myDate.getFullYear();break;  
  194.         case 'm' :partStr = myDate.getMonth()+1;break;  
  195.         case 'd' :partStr = myDate.getDate();break;  
  196.         case 'w' :partStr = Week[myDate.getDay()];break;  
  197.         case 'ww' :partStr = myDate.WeekNumOfYear();break;  
  198.         case 'h' :partStr = myDate.getHours();break;  
  199.         case 'n' :partStr = myDate.getMinutes();break;  
  200.         case 's' :partStr = myDate.getSeconds();break;  
  201.     }  
  202.     return partStr;  
  203. }  
  204.   
  205. //+---------------------------------------------------  
  206. //| 取得当前日期所在月的最大天数  
  207. //+---------------------------------------------------  
  208. Date.prototype.MaxDayOfDate = function()  
  209. {   
  210.     var myDate = this;  
  211.     var ary = myDate.toArray();  
  212.     var date1 = (new Date(ary[0],ary[1]+1,1));  
  213.     var date2 = date1.dateAdd(1,'m',1);  
  214.     var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));  
  215.     return result;  
  216. }  
  217.   
  218. //+---------------------------------------------------  
  219. //| 取得当前日期所在周是一年中的第几周  
  220. //+---------------------------------------------------  
  221. Date.prototype.WeekNumOfYear = function()  
  222. {   
  223.     var myDate = this;  
  224.     var ary = myDate.toArray();  
  225.     var year = ary[0];  
  226.     var month = ary[1]+1;  
  227.     var day = ary[2];  
  228.     document.write('< script language=VBScript\> \n');  
  229.     document.write('myDate = DateValue(''+month+'-'+day+'-'+year+'') \n');  
  230.     document.write('result = DatePart('ww', myDate) \n');  
  231.     document.write(' \n');  
  232.     return result;  
  233. }  
  234.   
  235. //+---------------------------------------------------  
  236. //| 字符串转成日期类型   
  237. //| 格式 MM/dd/YYYY MM-dd-YYYY YYYY/MM/dd YYYY-MM-dd  
  238. //+---------------------------------------------------  
  239. function StringToDate(DateStr)  
  240. {   
  241.   
  242.     var converted = Date.parse(DateStr);  
  243.     var myDate = new Date(converted);  
  244.     if (isNaN(myDate))  
  245.     {   
  246.         //var delimCahar = DateStr.indexOf('/')!=-1?'/':'-';  
  247.         var arys= DateStr.split('-');  
  248.         myDate = new Date(arys[0],--arys[1],arys[2]);  
  249.     }  
  250.     return myDate;  
  251. }  
分享到:
评论

相关推荐

    javascript 日期时间函数(经典+完善+实用)

    本文档将详细介绍一系列实用且功能全面的JavaScript日期时间处理函数,包括判断是否为闰年、日期格式化、日期加减计算、日期比较等。 #### 2. 日期时间脚本库方法列表 下面逐一介绍这些函数及其用法: ##### 2.1 ...

    javascript实现日期选择

    该函数用于在给定日期上增加或减少指定的时间间隔,支持年(y)、月(m)、日(d)和周(w)四种间隔类型。 **参数说明:** - `interval` (String): 时间间隔类型,可选值为 "y"(年)、"m"(月)、"d"(日)、"w...

    js成品日期控件

    JavaScript日期控件是一种在网页上实现用户交互式选择日期的工具,它可以帮助用户方便地输入或选择日期,常用于表单填写、事件预订等场景。本篇将详细讲解一款名为"js成品日期控件"的资源,包括其源码结构、使用方法...

    js公历日期转农历日期.txt

    本代码实现了一个简单的 JavaScript 函数,用于将公历日期转换为农历日期,并提供了农历节日和节气的相关信息。 ##### 3.1 内存布局 代码中首先定义了一个数组 `lunarInfo`,该数组包含了农历月份的信息,每个元素...

    js实现的网页中经典的带时分秒的时钟控件

    此外,`My97DatePicker`可能是一个流行的JavaScript日期选择插件,它提供了更丰富的日期时间选择功能,比如日期范围选择、自定义样式等,可以与这个时钟控件配合使用,提供更完善的日期时间管理体验。 总之,通过...

    日历时间JavaScript

    总结来说,"日历时间JavaScript"是JavaScript在Web开发中处理日期和时间的一种方式,`laydate`是一个实用的JavaScript日期插件,它提供了一套完善的API和丰富的样式,使得在网页上实现交互式日历控件变得简单易行。...

    js获取N月后或者N月前的时间(附源码).pdf

    `js获取N月后或者N月前的时间`这个主题涉及到了JavaScript中的Date对象以及日期的增减操作。以下是对这一知识点的详细说明: JavaScript的Date对象是内置的,用于表示特定的瞬间,精确到毫秒。我们可以通过创建一个...

    最漂亮的时间选择控件

    本文将深入探讨如何创建一个既美观又实用的时间选择控件,主要基于JSP、JavaScript以及自定义JS实现。 首先,我们要明确这个“最漂亮”的时间选择控件是由前人的经验基础上进一步完善的。这意味着我们在设计时需要...

    Python-小巧实用的JavaScript工具类库

    - **丰富的工具函数**:如同Python的内置模块一样,Vtils可能提供了各种实用的工具函数,比如字符串处理、数组操作、日期时间操作、类型检查、深度拷贝等。 - **模块化设计**:为了支持摇树优化,Vutil可能采用了...

    等待下班js倒计时代码

    在本场景中,"等待下班js倒计时代码"指的是一个使用JavaScript编写的程序,用于显示剩余到下班时间的倒计时。这种类型的代码通常会结合服务器时间或者用户本地时间来计算距离特定下班时间(例如18:00)的剩余分钟或...

    jquery+jqueryui实现日历日期万年历查询实例源码.rar

    在IT行业中,前端开发经常会遇到需要处理日期和时间的场景,比如日历插件的实现。本实例聚焦于“jQuery + jQuery UI”框架下构建的日历日期万年历查询功能,这是一种常见且实用的交互元素,广泛应用于网页表单、事件...

    javascript实现日期格式转换

    这种通过JavaScript进行的日期格式转换方法非常简单且实用。它能够帮助开发者快速将用户输入的各种日期格式统一为一个标准格式,以便于后续的数据处理和存储。在项目中频繁地遇到需要对日期格式进行处理的场景,因此...

    严格的三级联动日期下拉菜单

    ### 严格的三级联动日期下拉菜单 在网页开发过程中,日期选择...对于那些需要频繁处理日期数据的应用来说,这样的组件无疑是极为实用的。开发者可以根据自己的需求进一步定制和完善这一组件,以满足更复杂的业务逻辑。

    convertjs一个简单的JavaScript转换库

    由于JavaScript的数据类型系统相对灵活,但同时也可能导致类型错误,convert.js这样的库就显得尤为实用。 描述中的"convert.js一个简单的JavaScript转换库"进一步确认了这是一个轻量级的解决方案,旨在为开发者提供...

    js有小时和分钟的日历

    【标题】"js有小时和分钟的日历"指的是在网页应用中使用JavaScript实现的一个功能完善的日历组件,它不仅能够显示日期,还包含了小时和分钟的选择,为用户提供更精确的时间选择能力。 【描述】"绝对不忽悠人很有用...

    最简单的闹钟 js代码js实现一个闹钟

    在JavaScript(JS)中实现一个简单的闹钟是一项基础但实用的任务。这涉及到对JavaScript时间处理的理解,事件监听以及DOM操作。下面将详细讲解如何通过JavaScript实现一个基本的闹钟功能。 首先,我们需要知道...

    Mtils是一套前端辅助代码集合,提供常用的数据校验、数据加密、扩展函数、便捷函数。.zip

    便捷函数是为了简化常见任务而设计的,例如日期时间处理、颜色转换、URL解析等。Mtils 中的便捷函数能够帮助开发者快速完成这些常见任务,减少代码量,提高开发效率。比如,可以轻松实现日期格式化,将复杂的时间戳...

    JS+CSS3电子数字时钟代码.zip

    5. **定时器(setInterval)**:JavaScript中的定时器函数每间隔一定时间执行一次指定的函数,用于实时更新时钟。 6. **事件绑定**:可能有事件监听器用于响应用户交互,比如刷新时间或调整时区。 7. **代码优化**:...

    js+html实现周岁年龄计算器.docx

    在现代Web开发中,利用JavaScript(简称JS)结合HTML来构建实用工具是常见的应用场景之一。本文将详细介绍如何使用JS与HTML来开发一个简单的周岁年龄计算器。此计算器能够根据用户输入的出生年月日计算出其当前的...

Global site tag (gtag.js) - Google Analytics