js 时间处理 扩展方法

本文介绍了一组实用的日期操作函数,包括字符串转日期、日期格式化、计算日期差及闰年判断等。这些函数适用于不同格式的日期字符串,并提供灵活的格式化选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

  /*

   函数:把字符串转换为日期对象

   参数:yyyy-mm-dd或yyyy/mm/dd形式的字符串

   返回:Date对象

   注:IE下不支持直接实例化日期对象,如new Date("2012-04-03")

    */

 

  Date.prototype.convertDate = function (date) {
        var flag = true;
           var newDate = new Date();
           var dateArray=[];
 
           if(date.indexOf("-")!=-1){
                    dateArray = date.split("-");
                    newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);
                    newDate.setHours(0, 0, 0);
           }else if(date.indexOf("/")!=-1){
                    dateArray = date.split("/");
                    newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);
                     newDate.setHours(0, 0, 0);
           }else{
                       newDate = null;
           }
           return newDate;
   };

 

 

  /*

   函数:计算两个日期之间的差值

   参数:date是日期对象

         flag:ms-毫秒,s-秒,m-分,h-小时,d-天,M-月,y-年

   返回:当前日期和date两个日期相差的毫秒/秒/分/小时/天

   */

 

Date.prototype.dateDiff = function (date, flag) {
     var msCount;
     var diff = this.getTime() - date.getTime();
     switch (flag) {
         case "ms":
             msCount = 1;
             break;
         case "s":
             msCount = 1000;
             break;
         case "m":
             msCount = 60 * 1000;
             break;
         case "h":
             msCount = 60 * 60 * 1000;
             break;
         case "d":
             msCount = 24 * 60 * 60 * 1000;
             break;
     }
     return Math.floor(diff / msCount);
 };

 

 

 

 

/*

函数:判断一个年份是否为闰年

返回:是否为闰年

 */

 

Date.prototype.isLeapYear = function () {
    var year = this.getFullYear();
    return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);
}

 

 

 

 /*

 函数:格式化日期

 参数:formatStr-格式化字符串

         d:将日显示为不带前导零的数字,如1

         dd:将日显示为带前导零的数字,如01

         ddd:将日显示为缩写形式,如Sun

         dddd:将日显示为全名,如Sunday

         M:将月份显示为不带前导零的数字,如一月显示为1

         MM:将月份显示为带前导零的数字,如01

         MMM:将月份显示为缩写形式,如Jan

         MMMM:将月份显示为完整月份名,如January

         yy:以两位数字格式显示年份

         yyyy:以四位数字格式显示年份

         h:使用12小时制将小时显示为不带前导零的数字,注意||的用法

         hh:使用12小时制将小时显示为带前导零的数字

         H:使用24小时制将小时显示为不带前导零的数字

         HH:使用24小时制将小时显示为带前导零的数字

         m:将分钟显示为不带前导零的数字

         mm:将分钟显示为带前导零的数字

         s:将秒显示为不带前导零的数字

         ss:将秒显示为带前导零的数字

         l:将毫秒显示为不带前导零的数字

         ll:将毫秒显示为带前导零的数字

         tt:显示am/pm

         TT:显示AM/PM

 返回:格式化后的日期

 */

 

Date.prototype.format = function (formatStr) {
     var date = this;
 
     /*
     函数:填充0字符
     参数:value-需要填充的字符串, length-总长度
     返回:填充后的字符串
     */
     var zeroize = function (value, length) {
         if (!length) {
             length = 2;
         }
         value = new String(value);
         for (var i = 0, zeros = ''; i < (length - value.length); i++) {
             zeros += '0';
         }
         return zeros + value;
     };
 
     return formatStr.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|M{1,4}|yy(?:yy)?|([hHmstT])\1?|[lLZ])\b/g, function($0) {
         switch ($0) {
             case 'd': return date.getDate();
             case 'dd': return zeroize(date.getDate());
             case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][date.getDay()];
             case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][date.getDay()];
             case 'M': return date.getMonth() + 1;
             case 'MM': return zeroize(date.getMonth() + 1);
             case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][date.getMonth()];
             case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][date.getMonth()];
             case 'yy': return new String(date.getFullYear()).substr(2);
             case 'yyyy': return date.getFullYear();
             case 'h': return date.getHours() % 12 || 12;
             case 'hh': return zeroize(date.getHours() % 12 || 12);
             case 'H': return date.getHours();
             case 'HH': return zeroize(date.getHours());
             case 'm': return date.getMinutes();
             case 'mm': return zeroize(date.getMinutes());
             case 's': return date.getSeconds();
             case 'ss': return zeroize(date.getSeconds());
             case 'l': return date.getMilliseconds();
             case 'll': return zeroize(date.getMilliseconds());
             case 'tt': return date.getHours() < 12 ? 'am' : 'pm';
             case 'TT': return date.getHours() < 12 ? 'AM' : 'PM';
         }
     });
 }
 
 
   document.writeln(  new Date().format("yyyy-MM-dd HH:MM:ss")+"</br>"); 
   document.writeln(  new Date().convertDate("2011/7/25")+"</br>"); 
   document.writeln(  new Date().isLeapYear("2011/7/25")+"</br>"); 
   document.writeln( new Date().dateDiff(new Date().convertDate("2012/7/25") , 'h'));
 
 

 

 

 
 
// 时间的对比  兼容ie火狐 
//两个时间对比 
function compareTime(startTime , endTime){
 
	var beginTimes = startTime.split('-');
	//var beginTimeTemp = beginTimes[1]+'-'+beginTimes[2]+'-'+beginTimes[0];
	var endTimes = endTime.split('-');
	if(beginTimes.length!=3 || endTimes.length!=3 ){
		return false;
	}
	//var endTimeTemp = endTimes[1]+'-'+endTimes[2]+'-'+endTimes[0];
	var beginT = new Date(beginTimes[0],beginTimes[1],beginTimes[2]).getTime();
	var endT = new Date(endTimes[0],endTimes[1],endTimes[2] ).getTime();
	var len = ( beginT- endT )/3600/1000;
	if(len>=0){
		return true;
	}else{
		return false;
	}
}
 
 
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值