JS實(shí)現(xiàn)處理時(shí)間,年月日,星期的公共方法示例
本文實(shí)例講述了JS實(shí)現(xiàn)處理時(shí)間,年月日,星期的公共方法。分享給大家供大家參考,具體如下:
在項(xiàng)目中用到的,用js 來(lái)得到年月日,星期,當(dāng)前多少個(gè)周的函數(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ù)計(jì)算在線工具供大家使用:
在線日期/天數(shù)計(jì)算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi
在線日期計(jì)算器/相差天數(shù)計(jì)算器:
http://tools.jb51.net/jisuanqi/datecalc
在線日期天數(shù)差計(jì)算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq
在線天數(shù)計(jì)算器:
http://tools.jb51.net/jisuanqi/datejsq
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript時(shí)間與日期操作技巧總結(jié)》、《JavaScript+HTML5特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
event對(duì)象獲取方法總結(jié)在google瀏覽器下測(cè)試
Event 對(duì)象代表事件的狀態(tài),比如事件在其中發(fā)生的元素、鍵盤按鍵的狀態(tài)、鼠標(biāo)的位置、鼠標(biāo)按鈕的狀態(tài),Event對(duì)象的獲取方法如下,感興趣的朋友可以參考下2013-11-11
帶有定位當(dāng)前位置的百度地圖前端web api實(shí)例代碼
這篇文章主要介紹了帶有定位當(dāng)前位置的百度地圖前端web api實(shí)例代碼 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
JavaScript中報(bào)錯(cuò)Cannot?set?properties?of?undefined?(settin
這篇文章主要介紹了JavaScript中報(bào)錯(cuò)Cannot?set?properties?of?undefined?(setting?'1')的解決方案,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或使用js具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2025-03-03
javascript實(shí)現(xiàn)數(shù)字驗(yàn)證碼的簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)javascript實(shí)現(xiàn)數(shù)字驗(yàn)證碼的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02
JS計(jì)算兩個(gè)時(shí)間相差分鐘數(shù)的方法示例
這篇文章主要介紹了JS計(jì)算兩個(gè)時(shí)間相差分鐘數(shù)的方法,結(jié)合完整實(shí)例形式分析了javascript針對(duì)日期時(shí)間的轉(zhuǎn)換與計(jì)算相關(guān)操作技巧,需要的朋友可以參考下2018-01-01
深入理解javascript prototype的相關(guān)知識(shí)
這篇文章主要介紹了深入理解javascript prototype的相關(guān)知識(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
JavaScript實(shí)現(xiàn)封閉區(qū)域布爾運(yùn)算的示例代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)封閉區(qū)域布爾運(yùn)算的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06

