js实现的日期操作类DateTime函数代码


Posted in Javascript onMarch 16, 2010
方法注解:
将指定的天数加到此实例的值上。
将指定的小时数加到此实例的值上。
将指定的分钟数加到此实例的值上。
将指定的毫秒数加到此实例的值上。
将指定的月份数加到此实例的值上。
将指定的秒数加到此实例的值上。
将指定的年份数加到此实例的值上。
将此实例的值与指定的 Date 值相比较,并指示此实例是早于、等于还是晚于指定的 Date 值。
返回一个数值相同的新DateTime对象
返回一个值,该值指示此实例是否与指定的 DateTime 实例相等。
获取此实例的日期部分。
获取此实例所表示的日期为该月中的第几天。
获取此实例所表示的日期是星期几。
获取此实例所表示日期的小时部分。
获取此实例所表示日期的分钟部分。
获取此实例所表示日期的毫秒部分。
获取此实例所表示日期的月份部分。
获取此实例的下个月一日的DateTime对象
获取此实例的下一个周日的DateTime对象
获取此实例的下一个周日的DateTime对象
获取此实例所表示日期的秒部分。
返回此实例的Date值
获取此实例所表示日期的年份部分。
指示此实例是否是DateTime对象
将当前 DateTime 对象的值转换为其等效的短日期字符串表示形式。
将当前 DateTime 对象的值转换为其等效的短时间字符串表示形式。
将当前 DateTime 对象的值转换为其等效的字符串表示形式。
验证Add系列的方法参数是否合法
继承自Date的方法
比较 DateTime 的两个实例,并返回它们相对值的指示。
返回指定年和月中的天数。
返回一个值,该值指示 DateTime 的两个实例是否相等。
返回指定的年份是否为闰年的指示。
获取一个 DateTime 对象,该对象设置为此计算机上的当前日期和时间,表示为本地时间。
将日期和时间的指定字符串表示形式转换为其等效的 DateTime。
获取当前日期,其时间组成部分设置为 00:00:00。
//表示时间上的一刻,通常以日期和当天的时间表示。 
function DateTime(year, month, day, hour, min, sec, millisec){ 
    var d = new Date();     if (year || year == 0){ 
        d.setFullYear(year); 
    } 
    if (month || month == 0){ 
        d.setMonth(month - 1); 
    } 
    if (day || day == 0){ 
        d.setDate(day); 
    } 
    if (hour || hour == 0){ 
        d.setHours(hour); 
    } 
    if (min || min == 0){ 
        d.setMinutes(min); 
    } 
    if (sec || sec == 0){ 
        d.setSeconds(sec); 
    } 
    if (millisec || millisec == 0){ 
        d.setMilliseconds(millisec); 
    } 
    //将指定的天数加到此实例的值上。 
    this.AddDays = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setDate(result.GetDay() + value); 
        return result; 
    } 
    //将指定的小时数加到此实例的值上。 
    this.AddHours = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setHours(result.GetHour() + value); 
        return result; 
    } 
    //将指定的分钟数加到此实例的值上。 
    this.AddMinutes = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setMinutes(result.GetMinute() + value); 
        return result; 
    } 
    //将指定的毫秒数加到此实例的值上。 
    this.AddMilliseconds = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setMilliseconds(result.GetMillisecond() + value); 
        return result; 
    } 
    //将指定的月份数加到此实例的值上。 
    this.AddMonths = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setMonth(result.GetValue().getMonth() + value); 
        return result; 
    } 
    //将指定的秒数加到此实例的值上。 
    this.AddSeconds = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setSeconds(result.GetSecond() + value); 
        return result; 
    } 
    //将指定的年份数加到此实例的值上。 
    this.AddYears = function(value){ 
        if(!ValidateAddMethodParam(value)){ 
            return null; 
        } 
        var result = this.Clone(); 
        result.GetValue().setFullYear(result.GetYear() + value); 
        return result; 
    }     
    //将此实例的值与指定的 Date 值相比较,并指示此实例是早于、等于还是晚于指定的 Date 值。 
    this.CompareTo = function(other){ 
        var internalTicks = other.getTime(); 
        var num2 = d.getTime(); 
     if (num2 > internalTicks) 
     { 
     return 1; 
     } 
     if (num2 < internalTicks) 
     { 
     return -1; 
     } 
     return 0; 
    } 
    //返回一个数值相同的新DateTime对象 
    this.Clone = function(){ 
        return new DateTime( 
             this.GetYear() 
            ,this.GetMonth() 
            ,this.GetDay() 
            ,this.GetHour() 
            ,this.GetMinute() 
            ,this.GetSecond() 
            ,this.GetMillisecond()); 
    } 
    //返回一个值,该值指示此实例是否与指定的 DateTime 实例相等。 
    this.Equals = function(other){ 
        return this.CompareTo(other) == 0; 
    } 
    //获取此实例的日期部分。 
    this.GetDate = function(){ 
        var result = new DateTime(d.getFullYear(), d.getMonth(), d.getDate(), 0, 0, 0, 0); 
        return result ; 
    } 
    //获取此实例所表示的日期为该月中的第几天。 
    this.GetDay = function(){ 
        return d.getDate(); 
    } 
    //获取此实例所表示的日期是星期几。 
    this.GetDayOfWeek = function(){ 
        return d.getDay(); 
    } 
    //获取此实例所表示日期的小时部分。 
    this.GetHour = function(){ 
        return d.getHours(); 
    } 
    //获取此实例所表示日期的分钟部分。 
    this.GetMinute = function(){ 
        return d.getMinutes(); 
    } 
    //获取此实例所表示日期的毫秒部分。 
    this.GetMillisecond = function(){ 
        return d.getMilliseconds(); 
    } 
    //获取此实例所表示日期的月份部分。 
    this.GetMonth = function(){ 
        return d.getMonth() + 1; 
    } 
    //获取此实例的下个月一日的DateTime对象 
    this.GetNextMonthFirstDay = function(){ 
        var result = new DateTime(this.GetYear(), this.GetMonth(), 1, 0, 0, 0, 0); 
        result = result.AddMonths(1); 
        return result; 
    } 
    //获取此实例的下一个周日的DateTime对象 
    this.GetNextWeekFirstDay = function(){ 
        var result = this.GetDate(); 
        return result.AddDays(7 - result.GetDayOfWeek()); 
    } 
    //获取此实例的下一个周日的DateTime对象 
    this.GetNextYearFirstDay = function(){ 
        return new DateTime(this.GetYear() + 1, 1, 1, 0, 0, 0, 0); 
    } 
    //获取此实例所表示日期的秒部分。 
    this.GetSecond = function(){ 
        return d.getSeconds(); 
    } 
    //返回此实例的Date值 
    this.GetValue = function(){ 
        return d; 
    } 
    //获取此实例所表示日期的年份部分。 
    this.GetYear = function(){ 
        return d.getFullYear(); 
    } 
    //指示此实例是否是DateTime对象 
    this.IsDateTime = function(){} 
    //将当前 DateTime 对象的值转换为其等效的短日期字符串表示形式。 
    this.ToShortDateString = function(){ 
        var result = ""; 
        result = d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate(); 
        return result;     
    } 
    //将当前 DateTime 对象的值转换为其等效的短时间字符串表示形式。 
    this.ToShortTimeString = function(){ 
        var result = ""; 
        result = d.getHours() + ":" + d.getMinutes() + ":" + d.getSeconds(); 
        return result;     
    } 
    //将当前 DateTime 对象的值转换为其等效的字符串表示形式。 
    this.ToString = function(format){ 
        if(typeof(format) == "string"){ 
        } 
        return this.ToShortDateString() + " " + this.ToShortTimeString(); 
    } 
    //验证Add系列的方法参数是否合法 
    function ValidateAddMethodParam(param){ 
        if(typeof(param) != "number"){ 
            return false; 
        } 
        return true; 
    } 
    //继承自Date的方法 
    this.getTime = function(){ 
        return d.getTime(); 
    } 
} 
//比较 DateTime 的两个实例,并返回它们相对值的指示。 
DateTime.Compare = function(d1, d2){ 
    return d1.CompareTo(d2); 
} 
//返回指定年和月中的天数。 
DateTime.DaysInMonth = function(year, month){ 
if ((month < 1) || (month > 12)) 
{ 
return "月份[" + month + "]超出范围"; 
} 
var numArray = DateTime.IsLeapYear(year) ? DateTime.DaysToMonth366 : DateTime.DaysToMonth365; 
return (numArray[month] - numArray[month - 1]); 
} 
//返回一个值,该值指示 DateTime 的两个实例是否相等。 
DateTime.Equals = function(d1, d2){ 
    return d1.CompareTo(d2) == 0; 
} 
//返回指定的年份是否为闰年的指示。 
DateTime.IsLeapYear = function(year) 
{ 
if ((year < 1) || (year > 0x270f)) 
{ 
return "年份[" + year + "]超出范围"; 
} 
if ((year % 4) != 0) 
{ 
return false; 
} 
if ((year % 100) == 0) 
{ 
return ((year % 400) == 0); 
} 
return true; 
} 
//获取一个 DateTime 对象,该对象设置为此计算机上的当前日期和时间,表示为本地时间。 
DateTime.Now = new DateTime(); 
//将日期和时间的指定字符串表示形式转换为其等效的 DateTime。 
DateTime.Parse = function(s){ 
    var result = new DateTime(); 
    var value = result.GetValue(); 
    value.setHours(0,0,0,0); 
    var dateRex = /\b[1-2][0-9][0-9][0-9][-]\d{1,2}[-]\d{1,2}\b/i; 
    if(dateRex.test(s)){ 
        var dateStr = s.match(dateRex)[0]; 
        try{ 
            var dateParts = dateStr.split("-"); 
            var year = dateParts[0] - 0; 
            var month = dateParts[1] - 1; 
            var day = dateParts[2] - 0; 
            value.setFullYear(year,month,day); 
        }catch(ex){ 
            return null; 
        } 
        var timeRex = /\b\d{1,2}[:]\d{1,2}[:]\d{1,2}\b/i; 
        if(timeRex.test(s)){ 
            var timeStr = s.match(timeRex)[0]; 
            try{ 
                var timeParts = timeStr.split(":"); 
                var hour = timeParts[0] - 0; 
                var min = timeParts[1] - 0; 
                var sec = timeParts[2] - 0; 
                value.setHours(hour,min,sec); 
            }catch(ex){ 
            } 
        } 
    }else{ 
        return null; 
    } 
    return result; 
} 
//获取当前日期,其时间组成部分设置为 00:00:00。 
DateTime.Today = new DateTime(null, null, null, 0, 0, 0, 0); 
//静态字段 
DateTime.DaysToMonth365 = [ 0, 0x1f, 0x3b, 90, 120, 0x97, 0xb5, 0xd4, 0xf3, 0x111, 0x130, 0x14e, 0x16d ]; 
DateTime.DaysToMonth366 = [ 0, 0x1f, 60, 0x5b, 0x79, 0x98, 0xb6, 0xd5, 0xf4, 0x112, 0x131, 0x14f, 0x16e ];
Javascript 相关文章推荐
jQuery 点击图片跳转上一张或下一张功能的实现代码
Mar 12 Javascript
javascript hashtable 修正版 下载
Dec 30 Javascript
Javascript对象中关于setTimeout和setInterval的this介绍
Jul 21 Javascript
jQuery(js)获取文字宽度(显示长度)示例代码
Dec 31 Javascript
JS加载iFrame出现空白问题的解决办法
May 13 Javascript
JS敏感词过滤代码
Dec 23 Javascript
深入学习 JavaScript中的函数调用
Mar 23 Javascript
详解Vue使用命令行搭建单页面应用
May 24 Javascript
vue-cli构建项目下使用微信分享功能
May 28 Javascript
Node.js连接Sql Server 2008及数据层封装详解
Aug 27 Javascript
node将geojson转shp返回给前端的实现方法
May 29 Javascript
js/jQuery实现全选效果
Jun 17 jQuery
javascript json2 使用方法
Mar 16 #Javascript
jQuery 选择器理解
Mar 16 #Javascript
jQuery 学习入门篇附实例代码
Mar 16 #Javascript
Jquery Ajax学习实例4 向WebService发出请求,返回实体对象的异步调用
Mar 16 #Javascript
Jquery Ajax学习实例3 向WebService发出请求,调用方法返回数据
Mar 16 #Javascript
javascript 二维数组的实现与应用
Mar 16 #Javascript
Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据
Mar 15 #Javascript
You might like
php下实现折线图效果的代码
2007/04/28 PHP
PHP中register_globals参数为OFF和ON的区别(register_globals 使用详解)
2012/02/05 PHP
php数组去重的函数代码
2013/02/03 PHP
浅析php创建者模式
2014/11/25 PHP
thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法
2016/05/19 PHP
yii2局部关闭(开启)csrf的验证的实例代码
2017/07/10 PHP
BOOM vs RR BO3 第二场2.13
2021/03/10 DOTA
javascript将数字转换整数金额大写的方法
2015/01/27 Javascript
javascript中定义类的方法详解
2015/02/10 Javascript
JS实现为表格动态添加标题的方法
2015/03/31 Javascript
javascript实现获取服务器时间
2015/05/19 Javascript
JS数组array元素的添加和删除方法代码实例
2015/06/01 Javascript
js实现TAB切换对应不同颜色的代码
2015/08/31 Javascript
超实用的JavaScript代码段 附使用方法
2016/05/22 Javascript
JavaScript遍历求解数独问题的主要思路小结
2016/06/12 Javascript
JS Ajax请求如何防止重复提交
2016/06/13 Javascript
JavaScript reduce和reduceRight详解
2016/10/24 Javascript
bootstrapValidator自定验证方法写法
2016/12/01 Javascript
windows下vue.js开发环境搭建教程
2017/03/20 Javascript
微信小程序实现多选删除列表数据功能示例
2019/01/15 Javascript
浅谈Webpack多页应用HMR卡住问题
2019/04/24 Javascript
Python中的模块导入和读取键盘输入的方法
2015/10/16 Python
python之matplotlib学习绘制动态更新图实例代码
2018/01/23 Python
Python基于机器学习方法实现的电影推荐系统实例详解
2019/06/25 Python
python中dict使用方法详解
2019/07/17 Python
Numpy 中的矩阵求逆实例
2019/08/26 Python
python 利用jinja2模板生成html代码实例
2019/10/10 Python
Python 爬虫的原理
2020/07/30 Python
利用HTML5 Canvas制作键盘及鼠标动画的实例分享
2016/03/15 HTML / CSS
英国最大线上综合鞋类商城:Office
2017/12/08 全球购物
表达自我的市场:Society6
2018/08/01 全球购物
环境科学专业个人求职信
2013/12/15 职场文书
茶叶店创业计划书范文
2014/01/19 职场文书
公务员政审个人总结
2015/02/12 职场文书
2015年质量月活动总结报告
2015/03/27 职场文书
雨雪天气温馨提示
2015/07/15 职场文书