`
刘逸君
  • 浏览: 38930 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

一个很不错的js时间的类

    博客分类:
  • 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 日期天数差
***/
//---------------------------------------------------  
// 判断闰年  
//---------------------------------------------------  
Date.prototype.isLeapYear = function()   
{   
    return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));   
}   
  
//---------------------------------------------------  
// 日期格式化  
// 格式 YYYY/yyyy/YY/yy 表示年份  
// MM/M 月份  
// W/w 星期  
// dd/DD/d/D 日期  
// hh/HH/h/H 时间  
// mm/m 分钟  
// ss/SS/s/S 秒  
//---------------------------------------------------  
Date.prototype.Format = function(formatStr)   
{   
    var str = formatStr;   
    var Week = ['日','一','二','三','四','五','六'];  
  
    str=str.replace(/yyyy|YYYY/,this.getFullYear());   
    str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100));   
  
    str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0' + this.getMonth());   
    str=str.replace(/M/g,this.getMonth());   
  
    str=str.replace(/w|W/g,Week[this.getDay()]);   
  
    str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate());   
    str=str.replace(/d|D/g,this.getDate());   
  
    str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours());   
    str=str.replace(/h|H/g,this.getHours());   
    str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes());   
    str=str.replace(/m/g,this.getMinutes());   
  
    str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds());   
    str=str.replace(/s|S/g,this.getSeconds());   
  
    return str;   
}   
  
//+---------------------------------------------------  
//| 求两个时间的天数差 日期格式为 YYYY-MM-dd   
//+---------------------------------------------------  
function daysBetween(DateOne,DateTwo)  
{   
    var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-'));  
    var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);  
    var OneYear = DateOne.substring(0,DateOne.indexOf ('-'));  
  
    var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-'));  
    var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);  
    var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-'));  
  
    var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);   
    return Math.abs(cha);  
}  
  
  
//+---------------------------------------------------  
//| 日期计算  
//+---------------------------------------------------  
Date.prototype.DateAdd = function(strInterval, Number) {   
    var dtTmp = this;  
    switch (strInterval) {   
        case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number));  
        case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number));  
        case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number));  
        case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number));  
        case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number));  
        case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
        case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
        case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
    }  
}  
  
//+---------------------------------------------------  
//| 比较日期差 dtEnd 格式为日期型或者 有效日期格式字符串  
//+---------------------------------------------------  
Date.prototype.DateDiff = function(strInterval, dtEnd) {   
    var dtStart = this;  
    if (typeof dtEnd == 'string' )//如果是字符串转换为日期型  
    {   
        dtEnd = StringToDate(dtEnd);  
    }  
    switch (strInterval) {   
        case 's' :return parseInt((dtEnd - dtStart) / 1000);  
        case 'n' :return parseInt((dtEnd - dtStart) / 60000);  
        case 'h' :return parseInt((dtEnd - dtStart) / 3600000);  
        case 'd' :return parseInt((dtEnd - dtStart) / 86400000);  
        case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7));  
        case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1);  
        case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear();  
    }  
}  
  
//+---------------------------------------------------  
//| 日期输出字符串,重载了系统的toString方法  
//+---------------------------------------------------  
Date.prototype.toString = function(showWeek)  
{   
    var myDate= this;  
    var str = myDate.toLocaleDateString();  
    if (showWeek)  
    {   
        var Week = ['日','一','二','三','四','五','六'];  
        str += ' 星期' + Week[myDate.getDay()];  
    }  
    return str;  
}  
  
//+---------------------------------------------------  
//| 日期合法性验证  
//| 格式为:YYYY-MM-DD或YYYY/MM/DD  
//+---------------------------------------------------  
function IsValidDate(DateStr)   
{   
    var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格;   
    if(sDate=='') return true;   
    //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为''   
    //数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式   
    var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2 }[\-/]{ 1 }[\d]{ 1,2 }/g,'');   
    if (s=='') //说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D   
    {   
        var t=new Date(sDate.replace(/\-/g,'/'));   
        var ar = sDate.split(/[-/:]/);   
        if(ar[0] != t.getYear() || ar[1] != t.getMonth()+1 || ar[2] != t.getDate())   
        {   
            //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');   
            return false;   
        }   
    }   
    else   
    {   
        //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');   
        return false;   
    }   
    return true;   
}   
  
//+---------------------------------------------------  
//| 日期时间检查  
//| 格式为:YYYY-MM-DD HH:MM:SS  
//+---------------------------------------------------  
function CheckDateTime(str)  
{   
    var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2 }):(\d{ 1,2 }):(\d{ 1,2 })$/;   
    var r = str.match(reg);   
    if(r==null)return false;   
    r[2]=r[2]-1;   
    var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);   
    if(d.getFullYear()!=r[1])return false;   
    if(d.getMonth()!=r[2])return false;   
    if(d.getDate()!=r[3])return false;   
    if(d.getHours()!=r[4])return false;   
    if(d.getMinutes()!=r[5])return false;   
    if(d.getSeconds()!=r[6])return false;   
    return true;   
}   
  
//+---------------------------------------------------  
//| 把日期分割成数组  
//+---------------------------------------------------  
Date.prototype.toArray = function()  
{   
    var myDate = this;  
    var myArray = Array();  
    myArray[0] = myDate.getFullYear();  
    myArray[1] = myDate.getMonth();  
    myArray[2] = myDate.getDate();  
    myArray[3] = myDate.getHours();  
    myArray[4] = myDate.getMinutes();  
    myArray[5] = myDate.getSeconds();  
    return myArray;  
}  
  
//+---------------------------------------------------  
//| 取得日期数据信息  
//| 参数 interval 表示数据类型  
//| y 年 m月 d日 w星期 ww周 h时 n分 s秒  
//+---------------------------------------------------  
Date.prototype.DatePart = function(interval)  
{   
    var myDate = this;  
    var partStr='';  
    var Week = ['日','一','二','三','四','五','六'];  
    switch (interval)  
    {   
        case 'y' :partStr = myDate.getFullYear();break;  
        case 'm' :partStr = myDate.getMonth()+1;break;  
        case 'd' :partStr = myDate.getDate();break;  
        case 'w' :partStr = Week[myDate.getDay()];break;  
        case 'ww' :partStr = myDate.WeekNumOfYear();break;  
        case 'h' :partStr = myDate.getHours();break;  
        case 'n' :partStr = myDate.getMinutes();break;  
        case 's' :partStr = myDate.getSeconds();break;  
    }  
    return partStr;  
}  
  
//+---------------------------------------------------  
//| 取得当前日期所在月的最大天数  
//+---------------------------------------------------  
Date.prototype.MaxDayOfDate = function()  
{   
    var myDate = this;  
    var ary = myDate.toArray();  
    var date1 = (new Date(ary[0],ary[1]+1,1));  
    var date2 = date1.dateAdd(1,'m',1);  
    var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));  
    return result;  
}  
  
//+---------------------------------------------------  
//| 取得当前日期所在周是一年中的第几周  
//+---------------------------------------------------  
Date.prototype.WeekNumOfYear = function()  
{   
    var myDate = this;  
    var ary = myDate.toArray();  
    var year = ary[0];  
    var month = ary[1]+1;  
    var day = ary[2];  
    document.write('< script language=VBScript\> \n');  
    document.write('myDate = DateValue(''+month+'-'+day+'-'+year+'') \n');  
    document.write('result = DatePart('ww', myDate) \n');  
    document.write(' \n');  
    return result;  
}  
  
//+---------------------------------------------------  
//| 字符串转成日期类型   
//| 格式 MM/dd/YYYY MM-dd-YYYY YYYY/MM/dd YYYY-MM-dd  
//+---------------------------------------------------  
function StringToDate(DateStr)  
{   
  
    var converted = Date.parse(DateStr);  
    var myDate = new Date(converted);  
    if (isNaN(myDate))  
    {   
        //var delimCahar = DateStr.indexOf('/')!=-1?'/':'-';  
        var arys= DateStr.split('-');  
        myDate = new Date(arys[0],--arys[1],arys[2]);  
    }  
    return myDate;  
}
分享到:
评论

相关推荐

    JS常用时间控件 很不错

    "JS常用时间控件 很不错"这个标题表明我们将探讨一个在JavaScript中实现的高效且用户体验良好的时间选择工具。 描述中的"做网页的时间控件,用用不错的,效果也不错"进一步强调了这个时间控件在实际应用中的表现和...

    一个不错的时间导航网页特效

    在这个案例中,"一个不错的时间导航网页特效"可能是对一种高效、美观且用户体验良好的时间线导航设计的描述。 在创建时间导航网页特效时,开发者通常会使用HTML、CSS和JavaScript这三种核心技术。HTML负责构建网页...

    一个不错的农历js例子

    JavaScript的`Date`对象主要基于公历(阳历)系统,因此,要实现农历功能,我们需要扩展这个对象或创建一个新的类来处理农历日期。 在“lunarCalendar”库中,开发者可能定义了一个名为`LunarDate`的类,这个类包含...

    jquery 很不错的多文件上传类

    在这个“jquery 很不错的多文件上传类”示例中,我们聚焦于利用jQuery实现一个ASP.NET环境下的多文件上传功能。这个功能在现代Web应用中尤其重要,因为它允许用户一次性上传多个文件,提高了用户体验。 首先,我们...

    不错的js特效代码样例

    JavaScript是一种广泛应用于网页和应用程序的脚本语言,它在客户端运行,为用户提供动态交互体验。在"不错的js特效代码样例"中,我们看到...对于想要深入理解和实践JavaScript特效的开发者来说,这是一个很好的资源库。

    一个不错的下雪效果

    "一个不错的下雪效果" 描述的是一种能够为用户带来冬季氛围的交互式特效,它能让访问者仿佛置身于飘雪的场景之中。这个插件简单易用,只需导入即可在网页上实现这种视觉效果。 首先,我们要理解下雪效果是如何实现...

    几个不错的日历控件,JS写的,个人感觉不错

    1. **My97DatePicker2.1**:这是一个经典的JavaScript日历控件,以其强大的功能和良好的兼容性而受到开发者欢迎。My97DatePicker支持精确到秒的时间选择,这在需要精确时间记录的应用中非常有用,例如在线会议预定或...

    javascript常用大收藏,非常有用,包含了常用到的各种js

    JavaScript是一种广泛应用于网页和网络应用的编程语言,尤其在客户端编程中扮演着核心角色。... 标题中的"javascript常用大收藏"意味着这个...对有经验的开发者来说,也是一个不错的参考资料,可以快速查阅和复用代码。

    一个非常不错的纯javascript+css网页进度条(值得收藏)

    这个资源“一个非常不错的纯javascript+css网页进度条”提供了一种使用JavaScript和CSS实现的高效、美观的进度条解决方案,无需依赖任何外部库,非常适合那些希望在网页中添加这种功能而不想增加额外负担的开发者。...

    c# 时间日期控件还不错

    它允许用户从弹出的日历中选择一个日期,或者直接在文本框中输入。DateTimePicker可以通过Format属性设置显示格式,如短日期、长日期、时间等。它的Value属性则可以获取或设置所选的日期和时间。 2. **Calendar** ...

    一个不错的网页模板框架

    这个"一个不错的网页模板框架"显然旨在为开发者提供一套预先设计和编写的HTML、CSS以及JavaScript代码,以便他们可以以此为基础进行二次开发,减少从零开始的工作量。 HTML(超文本标记语言)是网页内容的基础结构...

    (ZenCart CJloader包含CSS和JS文件类)yellow1912-cjloader-d268660

    CJ Loader插件包含了 PHP Minify(一个php开源项目,用于合并和压缩 CSS和JS文件),让zencart网站中的经过它优化压缩后的CSS和JS文件,缓存在浏览者的浏览器中一定时间(我看了默认配置是一年)。 2.提升开发速度 CJ ...

    五日学会js教程(很不错)

    JavaScript,简称JS,是Web开发领域中最常用的编程语言之一,被广泛用于网页和网络应用的交互、动态内容的实现以及用户界面的优化。本“五日学会js教程”旨在帮助初学者在短时间内快速掌握JavaScript的核心概念和...

    js显示时间代码

    ### JavaScript显示时间代码知识点解析 #### 一、概述 ...对于希望进一步提升自己编程技能的学习者来说,尝试优化现有代码或扩展其功能(如添加日期显示、不同时间格式的支持等)也是一个不错的选择。

    JSA脚本压缩工具

    总的来说,JSA脚本压缩工具以其简单易用的特性,为JavaScript开发者提供了一个快速压缩代码的解决方案,帮助优化网页性能,减少用户等待时间。尽管现代有许多替代工具,但每个工具都有其独特的优势和适用场景,选择...

    40个轻量级JavaScript库

    这对于需要快速集成用户交互对话的应用来说是一个很好的选择。 **GameJS** 是一个基于 JavaScript 的游戏开发框架,它移植自微软的 XNA 游戏框架,并使用 HTML5 的 Canvas API 作为渲染后端。尽管 JavaScript 并不...

    js例子,不错的例子

    JavaScript,简称JS,是一种广泛应用于Web开发的轻量级、解释型编程语言,以其灵活性和交互性在网页设计中占据...对于初学者,这是一个很好的学习资源;对于经验丰富的开发者,也可以从中找到灵感和优化代码的方法。

    不错的js网页特效图片切换

    在图片切换中,我们可以创建一个包含所有图片的HTML结构,然后利用JavaScript来改变这些图片的显示状态,如设置`display`属性为`none`或`block`,或者使用CSS类来控制可见性。 2. 事件监听:当用户触发特定事件(如...

    Js双日历控件,同时显示两个日期选择器

    Js双日历控件,在一个网页上同时显示两个日期选择器,写成了封装类,方便使用者调用。同时美化的相当不错。  包括了以下函数:  1、2012——2020年节假日信息(包括节假日前1~3天/后1~3天)  2、格式化数字,...

    一个不错的路径菜单网页特效

    标题"一个不错的路径菜单网页特效"表明我们将探讨一个优秀的路径菜单实现,它可能包含动画效果、响应式设计或者独特的视觉表现,旨在提升用户体验。 路径菜单通常表现为面包屑导航(Breadcrumb Navigation),这是...

Global site tag (gtag.js) - Google Analytics