`
全城热恋
  • 浏览: 618 次
  • 性别: Icon_minigender_1
  • 来自: 江苏
社区版块
存档分类
最新评论

js日期的常用操作

    博客分类:
  • js
阅读更多

    //---------------------------------------------------  
    // 判断闰年  
    //---------------------------------------------------  
    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()+1).toString():'0' + (this.getMonth()+1));   
        str=str.replace(/M/g,this.getMonth()+1);   
      
        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.Format('MM/dd/yyyy HH:mm:ss')) + (1000 * Number));  
            case 'n' :return new Date(Date.parse(dtTmp.Format('MM/dd/yyyy HH:mm:ss')) + (60000 * Number));  
            case 'h' :return new Date(Date.parse(dtTmp.Format('MM/dd/yyyy HH:mm:ss')) + (3600000 * Number));  
            case 'd' :return new Date(Date.parse(dtTmp.Format('MM/dd/yyyy HH:mm:ss')) + (86400000 * Number));  
            case 'w' :return new Date(Date.parse(dtTmp.Format('MM/dd/yyyy HH:mm:ss')) + ((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));  
        var date2 = date1.DateAdd('m',1);  
        var result = date1.DateDiff('d',date2);  
        return result;  
    }  
    //+---------------------------------------------------  
    //| 取得当前日期所在月的第一天  
    //+--------------------------------------------------- 
    Date.prototype.MounthFirstDay = function()  
    {   
        var myDate = this;  
        var ary = myDate.toArray();  
        return  (new Date(ary[0],ary[1],1));
    }  
    //+---------------------------------------------------  
    //| 取得当前日期所在月的最后一天  
    //+--------------------------------------------------- 
    Date.prototype.MounthLastDay = function()  
    {   
        var myDate = this;  
        var ary = myDate.toArray();  
        return  (new Date(ary[0],ary[1],myDate.MaxDayOfDate()));
    }  
   //+---------------------------------------------------  
    //| 取得当前日期所在周的第一天  
    //+---------------------------------------------------
    Date.prototype.WeekFirstDay = function()  
    {   
        var myDate = this;  
        var ary = myDate.getDay();
        if(ary==0){
        	return myDate.DateAdd('d',-6);
        } else {
        	return myDate.DateAdd('d',-ary+1);
        }
        
    } 
    
    //+---------------------------------------------------  
    //| 取得当前日期所在周的最后一天  
    //+---------------------------------------------------
    Date.prototype.WeekLastDay = function()  
    {   
        var myDate = this;  
        var ary = myDate.getDay();
        if(ary==0){
        	return myDate;
        } else {
        	return myDate.DateAdd('d',7-ary);
        }
      
    }  
    
    //+---------------------------------------------------  
    //| 取得当前日期所在周是一年中的第几周  
    //+---------------------------------------------------  
    Date.prototype.WeekNumOfYear = function()  
    {   
        var myDate = this;  
        var ary = myDate.toArray();  
        var year = ary[0];  
        var month = ary[1]+1;  
        var day = ary[2];
        return DatePart('ww', DateValue(''+month+'-'+day+'-'+year+''));  
    }  
      
    //+---------------------------------------------------  
    //| 字符串转成日期类型   
    //| 格式 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(delimCahar);  
            myDate = new Date(arys[0],arys[1],arys[2]);  
        }  
        return myDate;  
    }  
    //+---------------------------------------------------  
    //| 相关操作的快捷封装  
    //+---------------------------------------------------  
    function getMyDay(typeId) {
    	var currentTime = new Date();
    	 switch (typeId) {   
    	            case 1 :
    	              //今天
    	                return currentTime.Format('yyyy-MM-dd');  
    	            case 2 :
    	             //昨天
    	             return currentTime.DateAdd('d',-1).Format('yyyy-MM-dd');
    	            case 3 :
    	             //当前月第一天
    	             return currentTime.MounthFirstDay().Format('yyyy-MM-dd');
    	            case 4 :
    	            //当前月最后一天
    	            return currentTime.MounthLastDay().Format('yyyy-MM-dd'); 
    	            case 5 :
    	            //当前周第一天
    	            return currentTime.WeekFirstDay().Format('yyyy-MM-dd'); 
    	            case 6 :
    	            //当前周最后一天
    	            return currentTime.WeekLastDay().Format('yyyy-MM-dd');  
    	            case 7 :
    	            //七天前日期
    	            return currentTime.DateAdd('d',-7).Format('yyyy-MM-dd');
    	            case 8 :
    	            //30天前日期
    	            return currentTime.DateAdd('d',-30).Format('yyyy-MM-dd');
    	            case 9 :
    	            //上周第一天
    	            return currentTime.DateAdd('w',-1).WeekFirstDay().Format('yyyy-MM-dd');
    	            case 10:
    	            //上周最后一天
    	            return currentTime.DateAdd('w',-1).WeekLastDay().Format('yyyy-MM-dd');
    	            case 11 :
    	            //上月第一天
    	            return currentTime.DateAdd('m',-1).MounthFirstDay().Format('yyyy-MM-dd');
    	            case 12:
    	            //上月最后一天
    	            return currentTime.DateAdd('m',-1).MounthLastDay().Format('yyyy-MM-dd');
    	            case 13:
    	            //上月最后一天
    	            return currentTime.Format('yyyy-MM-dd');
    	            
    	   }  
    	}
  



分享到:
评论

相关推荐

    js日期时间控件 JavaScriptjs日期时间控件 jsp

    JavaScript日期时间控件是网页开发中常用的一种组件,主要用于用户在网页上选择或输入日期和时间。在JavaScript中,处理日期和时间的核心对象是`Date`。本篇将深入探讨JavaScript日期时间控件的实现原理、使用方法...

    js日期选择插件

    JavaScript日期选择插件是网页开发中常用的一种工具,主要用于用户在网页上方便地选择日期,常见于表单输入、日历应用以及各种需要处理日期的交互场景。在本压缩包中,你将找到一个js日期插件,它允许开发者自定义...

    js时间日期输入框

    `WdatePicker`是一款功能丰富的JavaScript日期选择插件,由中国Web开发社区开发,支持多种日期格式,提供多种语言环境,并且具有日期计算、日期限制、日期校验等功能。其使用非常简便,只需要在HTML中添加一个`...

    非常好用的js日期控件

    在网页开发中,JavaScript(简称JS)是一种常用的客户端脚本语言,用于实现动态交互效果。日期控件是网页中常见的一种交互元素,它允许用户方便地选择日期,常用于表单填写、事件安排等场景。本资源提供的“非常好用...

    Javascript 日期对象Date扩展

    Date对象扩展,包括常用中文日期格式解析、加减操作、日期差、周操作和季操作。具体扩展的方法如下: parseCHS--静态方法。解析常用的中文日期并返回日期对象。 add--日期加减操作。[注:此函数在上传时还存在...

    常用的日期JS组件

    这篇博客“常用的日期JS组件”很可能介绍了一些常用的JavaScript日期组件,帮助我们更高效地进行日期处理。 首先,我们来了解一下JavaScript原生的Date对象。Date对象用于处理日期和时间,它可以创建一个新的日期...

    很实用的纯JS日期控件

    在JavaScript(JS)中,日期控件是一种常用的用户界面组件,允许用户选择日期或时间。在Web开发中,尤其在创建交互式表单或者需要处理日期输入的应用时,这种控件非常有用。以下是对"纯JS日期控件"的详细说明。 ...

    javascript 日期控件带时间

    本篇文章将详细探讨如何创建一个带有时间选择功能的JavaScript日期控件。 首先,`Date`对象是JavaScript中的核心对象之一,用于处理日期和时间。它提供了多种方法来创建、操作和格式化日期,例如`new Date()`用于...

    js日期控件,可以选择时间,很好用

    JavaScript日期对象(`Date`对象)是处理日期和时间的核心,它提供了许多方法来创建、格式化和操作日期。例如,`new Date()`可以创建当前日期和时间,`getFullYear()`、`getMonth()`、`getDate()`等方法可以获取年、...

    javascript 日期控件

    JavaScript 日期控件是网页开发中常用的一种交互元素,它允许用户在网页上方便地选择日期,常用于表单填写、日程安排等场景。在本案例中,我们有两个文件:`date.html` 和 `setday.js`。前者是HTML页面,后者是...

    JS日期选择插件

    JavaScript日期选择插件是网页开发中常用的一种工具,主要用于用户在网页上方便地选取日期,常见于表单输入、事件预约或日历功能等场景。本文将深入探讨基于JavaScript的日期选择控件及其核心概念。 首先,让我们...

    日期选择js插件

    日期选择js插件是网页开发中常用的一种工具,主要用于用户在网页上方便地选择日期,常见于表单填写、事件预约、日历应用等场景。JavaScript(简称js)作为前端开发的主要语言,提供了多种实现日期选择功能的插件。...

    Js获取当前日期时间及格式化代码

    描述中的知识点:介绍了如何使用JavaScript(Js)获取当前的日期和时间,并提供了一个格式化日期时间的代码示例。 标签中的知识点:涉及到Js在获取日期时间方面相关的几个关键功能和方法,包括获取年份、月份、日、...

    带时间选择的JS日期控件源码

    JS(JavaScript)是一种常用的客户端脚本语言,用于增强网页的交互性和动态性。在这个特定的源码中,JS被用来创建一个自定义的日期时间选择器,它可能包含以下关键知识点: 1. **DOM操作**:JS通过操作DOM(文档...

    JS日期选择器带时分秒

    在JavaScript(JS)中,日期选择器是一种常用的交互组件,用于让用户方便地选取日期和时间。"JS日期选择器带时分秒"是指一个能够显示并允许用户选择具体到秒的日期时间选择器。这样的功能在许多Web应用程序中非常...

    javascript常用函数 javascript 常用库

    4. Moment.js:处理日期和时间的强大库,提供了丰富的API来解析、验证、操作和显示日期。 5. Axios:一个基于Promise的HTTP库,可以在浏览器和node.js中使用,用于发送Ajax请求。 三、公共方法 在`common.base.js...

    HTML_JS实现很好的日期控件

    日期控件是网页设计中常用的一种元素,用户可以方便地选择日期,常用于表单填写、事件预订或日历应用等场景。在本教程中,我们将深入探讨如何使用 HTML 和 JavaScript 实现一个功能丰富的日期选择器。 首先,HTML ...

    日期选择并带输入框JS插件

    日期选择并带输入框的JS插件是一种常用的前端开发工具,它允许用户在网页上方便地选择日期,同时提供一个输入框供用户手动输入日期。这样的插件在各种Web应用程序中都十分常见,例如在线预订系统、日程管理工具、...

    JS日历插件日期选择器

    JavaScript(简称JS)日历插件是一种常用的前端交互组件,用于在网页上提供直观的日期选择功能。在网页设计和开发中,日期选择器通常用于处理与日期相关的表单输入,如预订系统、事件安排或者在线调查等。下面将详细...

    JavaScript日期控件四个

    Moment.js是一个强大的JavaScript日期库,用于解析、验证、操作和显示日期。虽然它本身并不提供日期选择器,但它可以与许多第三方插件(如eonasdan/bootstrap-datetimepicker)结合使用,创建出强大的日期和时间...

Global site tag (gtag.js) - Google Analytics