這篇文章將為大家詳細講解有關(guān)JavaScript中有哪些時間處理函數(shù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
企業(yè)建站必須是能夠以充分展現(xiàn)企業(yè)形象為主要目的,是企業(yè)文化與產(chǎn)品對外擴展宣傳的重要窗口,一個合格的網(wǎng)站不僅僅能為公司帶來巨大的互聯(lián)網(wǎng)上的收集和信息發(fā)布平臺,創(chuàng)新互聯(lián)建站面向各種領(lǐng)域:石雕等網(wǎng)站設(shè)計、營銷型網(wǎng)站建設(shè)解決方案、網(wǎng)站設(shè)計等建站排名服務(wù)。
一、把字符串轉(zhuǎn)換為日期對象
有時需要把字符串轉(zhuǎn)換為日期對象,但是IE下不支持new Date(“2011-04-07”)這樣實例化日期對象,ff下支持,所以寫了一個擴展函數(shù),用來把形如yyyy-mm-dd或者dd/mm/yyyy的字符串轉(zhuǎn)換為日期對象。代碼如下:
/* 函數(shù):把字符串轉(zhuǎn)換為日期對象 參數(shù):yyyy-mm-dd或dd/mm/yyyy形式的字符串 返回:Date對象 注:IE下不支持直接實例化日期對象,如new Date("2011-04-06") */ Date.prototype.convertDate = function (date) { var flag = true; var dateArray = date.split("-"); if (dateArray.length != 3) { dateArray = date.split("/"); if (dateArray.length != 3) { return null; } flag = false; } var newDate = new Date(); if (flag) { // month從0開始 newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]); } else { newDate.setFullYear(dateArray[2], dateArray[1] - 1, dateArray[0]); } newDate.setHours(0, 0, 0); return newDate; };
測試:
輸出:
Wed Dec 07 2011 17:30:58 GMT+0800
二、計算兩個日期之間的差值
這個函數(shù)可以計算兩個日期之前的差值(毫秒/秒/分/小時/天),主要用到了getTime()函數(shù)和Math.floor()函數(shù),代碼如下:
/* 函數(shù):計算兩個日期之間的差值 參數(shù):date是日期對象 flag:ms-毫秒,s-秒,m-分,h-小時,d-天,M-月,y-年 返回:當(dāng)前日期和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); };
測試:
結(jié)果:
1
三、判斷一個年份是否為閏年
代碼:
/* 函數(shù):判斷一個年份是否為閏年 返回:是否為閏年 */ Date.prototype.isLeapYear = function () { var year = this.getFullYear(); return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0); }
測試:
結(jié)果:
true
false
四、格式化日期
這個函數(shù)是從網(wǎng)上搜來的,稍微修改了一下,它類似.net中Format函數(shù),傳入格式化字符串如”yyyy-MM-dd”,返回格式化后的日期。
/* 函數(shù):格式化日期 參數(shù):formatStr-格式化字符串 d:將日顯示為不帶前導(dǎo)零的數(shù)字,如1 dd:將日顯示為帶前導(dǎo)零的數(shù)字,如01 ddd:將日顯示為縮寫形式,如Sun dddd:將日顯示為全名,如Sunday M:將月份顯示為不帶前導(dǎo)零的數(shù)字,如一月顯示為1 MM:將月份顯示為帶前導(dǎo)零的數(shù)字,如01 MMM:將月份顯示為縮寫形式,如Jan MMMM:將月份顯示為完整月份名,如January yy:以兩位數(shù)字格式顯示年份 yyyy:以四位數(shù)字格式顯示年份 h:使用12小時制將小時顯示為不帶前導(dǎo)零的數(shù)字,注意||的用法 hh:使用12小時制將小時顯示為帶前導(dǎo)零的數(shù)字 H:使用24小時制將小時顯示為不帶前導(dǎo)零的數(shù)字 HH:使用24小時制將小時顯示為帶前導(dǎo)零的數(shù)字 m:將分鐘顯示為不帶前導(dǎo)零的數(shù)字 mm:將分鐘顯示為帶前導(dǎo)零的數(shù)字 s:將秒顯示為不帶前導(dǎo)零的數(shù)字 ss:將秒顯示為帶前導(dǎo)零的數(shù)字 l:將毫秒顯示為不帶前導(dǎo)零的數(shù)字 ll:將毫秒顯示為帶前導(dǎo)零的數(shù)字 tt:顯示am/pm TT:顯示AM/PM 返回:格式化后的日期 */ Date.prototype.format = function (formatStr) { var date = this; /* 函數(shù):填充0字符 參數(shù):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'; } }); }
測試:
結(jié)果:
2011-04-08 10:13:37
關(guān)于JavaScript中有哪些時間處理函數(shù)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。