整理一些JavaScript時間處理擴充函數

來源:互聯網
上載者:User

在JavaScript中,時間處理是經常需要用到的。最近想要慢慢建立自己的程式碼程式庫,整理了幾個之前用到的js處理時間的函數,發出來跟大家分享一下,以後的使用中會不斷增加和修改程式碼程式庫。

把字串轉換為日期對象

有時需要把字串轉換為日期對象,但是IE下不支援new Date("2011-04-07")這樣執行個體化日期對象,ff下支援,所以寫了一個擴充函數,用來把形如yyyy-mm-dd或者dd/mm/yyyy的字串轉換為日期對象。代碼如下:

/*函數:把字串轉換為日期對象參數: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;};

測試:

<script type="text/javascript">  document.writeln(new Date().convertDate("7/12/2011"));</script>

輸出:Wed Dec 07 2011 17:30:58 GMT+0800

計算兩個日期之間的差值

這個函數可以計算兩個日期之前的差值(毫秒/秒/分/小時/天),主要用到了getTime()函數和Math.floor()函數,代碼如下:

/*函數:計算兩個日期之間的差值參數: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);};

測試:

<script type="text/javascript">  var d1 = new Date().convertDate("2011-04-08");  var d2 = new Date().convertDate("2011-04-07");  document.writeln(d1.dateDiff(d2, 'd'));</script>
判斷一個年份是否為閏年
 /*函數:判斷一個年份是否為閏年返回:是否為閏年*/Date.prototype.isLeapYear = function () {var year = this.getFullYear();return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);}

測試:

<script type="text/javascript">  document.writeln(new Date().convertDate("2000-04-08").isLeapYear() + "
");  document.writeln(new Date().convertDate("2011-04-08").isLeapYear() + "
");</script>// 結果:// true// false
格式化日期

這個函數是從網上搜來的,稍微修改了一下,它類似.net中Format函數,傳入格式化字串如"yyyy-MM-dd",返回格式化後的日期。

/*函數:格式化日期參數:formatStr-格式化字串d:將日顯示為不帶前置字元為零的數字,如1dd:將日顯示為帶前置字元為零的數字,如01ddd:將日顯示為縮寫形式,如Sundddd:將日顯示為全名,如SundayM:將月份顯示為不帶前置字元為零的數字,如一月顯示為1MM:將月份顯示為帶前置字元為零的數字,如01MMM:將月份顯示為縮寫形式,如JanMMMM:將月份顯示為完整月份名,如Januaryyy:以兩位元字格式顯示年份yyyy:以四位元字格式顯示年份h:使用12小時制將小時顯示為不帶前置字元為零的數字,注意||的用法hh:使用12小時制將小時顯示為帶前置字元為零的數字H:使用24小時制將小時顯示為不帶前置字元為零的數字HH:使用24小時制將小時顯示為帶前置字元為零的數字m:將分鐘顯示為不帶前置字元為零的數字mm:將分鐘顯示為帶前置字元為零的數字s:將秒顯示為不帶前置字元為零的數字ss:將秒顯示為帶前置字元為零的數字l:將毫秒顯示為不帶前置字元為零的數字ll:將毫秒顯示為帶前置字元為零的數字tt:顯示am/pmTT:顯示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';}});}

測試:

<script type="text/javascript">  document.writeln(new Date().format("yyyy-MM-dd hh:mm:ss"));</script>// 結果:// 2011-04-08 10:13:37

以後的工作和學習中,會不斷增加和完善自己的程式碼程式庫,有什麼問題請多多指教。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.