JS實現(xiàn)處理時間,年月日,星期的公共方法示例
本文實例講述了JS實現(xiàn)處理時間,年月日,星期的公共方法。分享給大家供大家參考,具體如下:
在項目中用到的,用js 來得到年月日,星期,當前多少個周的函數(shù),備忘在這里,以后參考。
Date.prototype.getWeek = function(){ var firstDayOfYear = new Date(this.getFullYear(),0,1); var millOfDay = 24*60*60*1000; return Math.ceil((((this - firstDayOfYear) / millOfDay) + firstDayOfYear.getDay()+1)/7); }; /* 01 October 2013-10:20:20 01 November 2013-10:20:20 01 December 2013-10:20:20 08 October 2013-01:55 pm */ var monthMapping = { "January" : "01", "February" : "02", "March" : "03", "April" : "04", "May" : "05", "June" : "06", "July" : "07", "August" : "08", "September" : "09", "October" : "10", "November" : "11", "December" : "12" }; function formatAmPm() { var dateTimeStr = arguments[0] ; var dateStr = dateTimeStr.split("-"); if (lang.currentLang == "zh_CN" || lang.currentLang == "zh_TW"){ var s_year = lang.getMessage('yearCn') ; var s_month = lang.getMessage('monthCn') ; var s_day = lang.getMessage('dayCn') ; var dateArray = dateStr[0].split(" ") ; var s_time = dateStr[1].split(" ")[1] == "am" ? lang.getMessage('amCn') :lang.getMessage('pmCn') ; var ret = dateArray[2] + s_year + monthMapping[dateArray[1]] + s_month + dateArray[0] + s_day + " " + s_time + dateStr[1].split(" ")[0] ; if ( arguments.length > 1 ){ /*admin feature ,so using en date*/ ret = arguments[1] ? dateStr[0] : dateStr[1] ; } return ret ; } else{ if ( arguments.length > 1 ){ return arguments[1] ? dateStr[0] : dateStr[1] ; } else{ return dateStr[0] + " " + dateStr[1] ; } } } function formatDate(dateTime, pattern) { if(pattern == "" || pattern == null) { pattern = "/"; } var date = new Date(dateTime); var year = date.getFullYear(); var month = date.getMonth()+1; month = month <10 ? '0'+month : month; var day = date.getDate(); day = day <10 ? '0'+day : day; return month + pattern + day + pattern + year; } function formatDateDDMMYYYY(dateTime) { var ymd = dateTime.split(" ")[0]; var dateArray = ymd.split("-"); return dateArray[2]+"."+dateArray[1]+"."+dateArray[0]; } /** * * @param dateTime YYYY-MM-DD hh:mm:ss */ function formatDateDDMMYY(dateTime){ var ymd = dateTime.split(" ")[0]; var dateArray = ymd.split("-"); return dateArray[2]+"."+dateArray[1]+"."+dateArray[0].substring(2); } /**********************calculate date*****************************/ var MONTH = [ {key:"Jan.",value:1}, {key:"Feb.",value:2}, {key:"Mar.",value:3}, {key:"Apr.",value:4}, {key:"May.",value:5}, {key:"Jun.",value:6}, {key:"Jul.",value:7}, {key:"Aug.",value:8}, {key:"Sept.",value:9}, {key:"Oct.",value:10}, {key:"Nov.",value:11}, {key:"Dec.",value:12} ]; var DAYS = [31,28,31,30,31,30,31,31,30,31,30,31]; function getYears(){ var years = []; var date = new Date(); var year = date.getFullYear(); var minYear = year - 10; for(var currentYear=minYear;currentYear <= year;currentYear++){ years.push(currentYear); } return years; }; function fillinMonthOptions(id,currentMonth){ $("#" + id).get(0).options.length = 0; for(var i= 0;i<MONTH.length; i++){ if (MONTH[i].value == currentMonth){ $("#" + id).append("<option value="+MONTH[i].value+" selected=\"selected\">"+MONTH[i].key+"</option>"); } else{ $("#" + id).append("<option value="+MONTH[i].value+">"+MONTH[i].key+"</option>"); } } }; function fillinAllMonthOptions(monthIds,currentMonth){ //var monthIds = ["loginMonth_1","loginMonth_2","auditMonth_1","auditMonth_2"]; for (var i=0;i<monthIds.length;i++){ fillinMonthOptions(monthIds[i],currentMonth); }; }; function fillinYearOptions(id,years,currentYear){ $("#" + id).get(0).options.length = 0; for(var i= 0;i<years.length; i++){ if (years[i] == currentYear){ $("#" + id).append("<option value="+years[i]+" selected=\"selected\">"+years[i]+"</option>"); } else{ $("#" + id).append("<option value="+years[i]+">"+years[i]+"</option>"); } } }; function fillinAllYearOptions(yearIds,currentYear){ //var yearIds = ["loginYear","auditYear"]; years = getYears(); for(var i= 0;i<yearIds.length; i++){ fillinYearOptions(yearIds[i],years,currentYear); } }; function isLeapYear(year){ return (year % 4 === 0) && (year % 100 !==0) || (year % 400 === 0); } /*get days of a month*/ function getMonthDays(year,month){ var monthDays = DAYS[month-1]; if (isLeapYear(year) && month == 2){ monthDays = 29; } return monthDays; } function fillinDay(id,monthDays){ $("#" + id).get(0).options.length = 0; for(var i=1;i<=monthDays;i++){ $("#" + id).append("<option value="+i+">"+i+"</option>"); } } function fiilinDays(year,month,dayIds){ var monthDays = getMonthDays(year,month); for(var i=0;i<dayIds.length;i++){ fillinDay(dayIds[i],monthDays); } } function getWeeksOfYear(year){ var firstDayOfYear = new Date(year,0,1); var days = firstDayOfYear.getDay() + (isLeapYear(year) ? 366 : 365); return Math.ceil(days/7); } function getCurrentWeekNo(){ var currentDate = new Date(); var firstDay = new Date(currentDate.getFullYear(),0,1); var dayms = 24 * 60 * 60 * 1000; var numday = ((currentDate - firstDay) / dayms ); var weeks = Math.ceil((numday + firstDay.getDay() + 1) / 7); return weeks; } function getWeekRangeOfWeek(year,weekNo){ var tmpDate = new Date("1/20/" + year); var numOfDaysPastSinceLastMonday = tmpDate.getDay()-1; tmpDate.setDate(tmpDate.getDate() - numOfDaysPastSinceLastMonday); var weekNoToday = tmpDate.getWeek(); var weeksInFuture = weekNo - weekNoToday; tmpDate.setDate(tmpDate.getDate() + (7 * weeksInFuture) ); var rangeFrom = tmpDate.getDate() + "/" + MONTH[tmpDate.getMonth()].key; tmpDate.setDate(tmpDate.getDate() + 6); var rangeTo = tmpDate.getDate() + "/" + MONTH[tmpDate.getMonth()].key ; return weekNo + "_#_" + rangeFrom + "_#_" + rangeTo ; } function fillinWeek(weekId,year){ $("#" + weekId).get(0).options.length = 0; var weeksOfYear = getWeeksOfYear(year); var weeks = []; for(var i=0;i<weeksOfYear;i++){ weeks.push(getWeekRangeOfWeek(year,i+1)); } for(var j=0;j<weeks.length;j++){ var week = weeks[j].split("_#_"); $("#" + weekId).append("<option value="+week[0]+">"+week[0] + "(" + week[1]+"-"+week[2]+")</option>"); } } function fillinWeeks(year,weekIds){ for (var i=0;i<weekIds.length;i++){ fillinWeek(weekIds[i],year); } }
PS:這里再為大家推薦幾款比較實用的天數(shù)計算在線工具供大家使用:
在線日期/天數(shù)計算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi
在線日期計算器/相差天數(shù)計算器:
http://tools.jb51.net/jisuanqi/datecalc
在線日期天數(shù)差計算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq
在線天數(shù)計算器:
http://tools.jb51.net/jisuanqi/datejsq
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript時間與日期操作技巧總結(jié)》、《JavaScript+HTML5特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
JS和Canvas實現(xiàn)圖片的預(yù)覽壓縮和上傳功能
這篇文章主要介紹了JS和Canvas實現(xiàn)圖片的預(yù)覽壓縮和上傳功能,實現(xiàn)此功能大概有兩步,第一步用戶選擇需要上傳的圖片,第二步獲取圖片資源壓縮預(yù)覽上傳,具體實現(xiàn)代碼大家參考下本文2018-03-03js 將圖片連接轉(zhuǎn)換成base64格式的簡單實例
下面小編就為大家?guī)硪黄猨s 將圖片連接轉(zhuǎn)換成base64格式的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08JavaScript面向?qū)ο髮崿F(xiàn)放大鏡案例
這篇文章主要為大家詳細介紹了JavaScript面向?qū)ο髮崿F(xiàn)放大鏡案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10一文了解JavaScript中call/apply/bind的使用
這篇文章主要介紹了一文了解JavaScript中call/apply/bind的使用,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07JavaScript實現(xiàn)數(shù)組全排列、去重及求最大值算法示例
這篇文章主要介紹了JavaScript實現(xiàn)數(shù)組全排列、去重及求最大值算法,結(jié)合實例形式分析了JavaScript針對數(shù)組的遞歸、遍歷、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07