在 JavaScript 中,Date 對象的方法遠遠不及其它語言多,很多常用的方法都沒有提供,上次在做 Calendar 項目的時候,自己又添加了一些方法,今天整理了一下,寫成了一個 dateHelper 對象,下次用的時候就不用再寫了。
var dateHelper = { isLeapYear: function(year){ //是否為閏年 if ((year % 400 == 0) || (year % 100 != 0) && (year % 4 == 0)) { return true; } else { return false; } }, daysInMonth: function(year, mo){ //返回指定月份中的天數 if (mo == 2) { return this.isLeapYear() ? 29 : 28; } else { return (mo == 4 || mo == 6 || mo == 9 || mo == 11) ? 30 : 31; } }, dayOfFirstDateInMonth: function(year,mo){//返回指定月份中第一天的星期數 var newDate = new Date(year, mo - 1); var day = newDate.getDay(); return day; },getClientTimeZone : function(){//返回用戶端時區var d = new Date();return -d.getTimezoneOffset()/60;}}
這些方法都是比較常用的,包括判斷是否為閏年,得到一個月的天數,得到用戶端的時區設定,dayOfFirstDateInMonth 方法在 Calendar 項目中用來返回某個月的1號是星期幾,以便產生日曆。另外,用 JavaScript 來擷取使用者的時區設定並不是最穩妥的辦法,至少在 windows 中,系統設定為某些時區時,JavaScript 的 getTimezoneOffset 方法並不能返回正確的值。有興趣的同學可以試一試。
PS. 其中的參數mo(月份),是以1為起始月的。
更多的方法以後遇到了再陸續更新。
下面的連結中的檔案包含了這段js代碼和demo,歡迎下載。
date_helper.zip