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 相关文章推荐
实例:尽可能写友好的Javascript代码
Oct 09 Javascript
JQuery下的Live方法和$.browser方法使用代码
Jun 02 Javascript
angularjs中的e2e测试实例
Dec 06 Javascript
jquery实现聚光灯效果的方法
Feb 06 Javascript
jQuery解决input超多的表单提交
Aug 10 Javascript
微信小程序 MD5的方法详解及实例代码
Mar 10 Javascript
Vue input控件通过value绑定动态属性及修饰符的方法
May 03 Javascript
js实现点击切换checkbox背景图片的简单实例
May 08 Javascript
vue-resource调用promise取数据方式详解
Jul 21 Javascript
浅谈Node 调试工具入门教程
Mar 20 Javascript
利用原生JS实现data方法示例代码
May 28 Javascript
el-table表头根据内容自适应完美解决表头错位和固定列错位
Jan 07 Javascript
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手册及PHP编程标准
2006/12/17 PHP
php 生成WML页面方法详解
2009/08/09 PHP
PHP删除数组中指定值的元素常用方法实例分析【4种方法】
2018/08/21 PHP
JavaScript Accessor实现说明
2010/12/06 Javascript
JS 实现Json查询的方法实例
2013/04/12 Javascript
jQuery DOM插入节点操作指南
2015/03/03 Javascript
jQuery实现form表单基于ajax无刷新提交方法详解
2015/12/08 Javascript
基于JavaScript实现类似于百度学术高级检索功能
2016/03/02 Javascript
简单了解JavaScript操作XPath的一些基本方法
2016/06/03 Javascript
AngularJS基础 ng-cloak 指令简单示例
2016/08/01 Javascript
浅谈JSON.stringify()和JOSN.parse()方法的不同
2016/08/29 Javascript
react native仿微信PopupWindow效果的实例代码
2017/08/07 Javascript
轻松搞定jQuery+JSONP跨域请求的解决方案
2018/03/06 jQuery
解决vue项目打包后提示图片文件路径错误的问题
2018/07/04 Javascript
vue单页面应用打开新窗口显示跳转页面的实例
2018/09/21 Javascript
JS高阶函数原理与用法实例分析
2019/01/15 Javascript
jsonp跨域获取百度联想词的方法分析
2019/05/13 Javascript
Vue多环境代理配置方法思路详解
2019/06/21 Javascript
微信小程序中悬浮窗功能的实现代码
2019/08/02 Javascript
vue输入节流,避免实时请求接口的实例代码
2019/10/30 Javascript
在Angular中实现一个级联效果的下拉框的示例代码
2020/05/20 Javascript
Vue实现圆环进度条的示例
2021/02/06 Vue.js
pyqt5 tablewidget 利用线程动态刷新数据的方法
2019/06/17 Python
Django中reverse反转并且传递参数的方法
2019/08/06 Python
python  logging日志打印过程解析
2019/10/22 Python
tensorflow之并行读入数据详解
2020/02/05 Python
Python Handler处理器和自定义Opener原理详解
2020/03/05 Python
pyautogui自动化控制鼠标和键盘操作的步骤
2020/04/01 Python
HTML5 新事件 小结
2009/07/16 HTML / CSS
HTML5 本地存储和内容按需加载的思路和方法
2011/04/07 HTML / CSS
Answear匈牙利:来自全球200多个知名时尚品牌
2017/04/21 全球购物
信息专业本科生个人的自我评价
2013/10/28 职场文书
公司门卫的岗位职责
2014/02/19 职场文书
质量承诺书范文
2014/03/27 职场文书
深入解析Apache Hudi内核文件标记机制
2022/03/31 Servers
《地。-关于地球的运动-》单行本第七集上市,小说家朝井辽献上期待又害怕的推荐文
2022/03/31 日漫