JS獲取日期的方法實例【昨天,今天,明天,前n天,后n天的日期】
本文實例講述了JS獲取日期的方法。分享給大家供大家參考,具體如下:
原理很簡單,一天的時間的毫秒數是1000*60*60*24,
前n天的日期就是現在日期換成毫秒-n*1000*60*60*24。
再把這個值換成日期即可(通過setTime方法)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>www.dbjr.com.cn 日期計算</title> <meta name="Generator" content="EditPlus"> <meta name="Author" content=""> <meta name="Keywords" content=""> <meta name="Description" content=""> </head> <body> <select id="num" name="num" style="width:150px" onchange="ff()"> <option value="-1">昨天</option> <option value="0">今天</option> <option value="1">明天</option> </select><br> <textarea id="ar" rows="3" cols="20"> haha </textarea> <br/> <input type="text" value="" name="bday" id="bday"/>天之前 <input type="button" onclick="bday()" value="計算"><br/> <input type="text" value="" name="aday" id="aday"/>天之后 <input type="button" onclick="aday()" value="計算"><br/> </body> <script> ff(); function ff(){ var obj=document.getElementById("num"); var v1=obj.options[obj.selectedIndex].text; var v2=obj.options[obj.selectedIndex].value; var tvv=giveDateStr(getTargetday(v2)); document.getElementById('ar').innerText=tvv; } function isInteger(obj) { var r = /^\+?[1-9][0-9]*$/; //正整數 return r.test(obj); } function bday(){ var bef=document.getElementById("bday").value; if(isInteger(bef)){ var bvv=giveDateStr(getTargetday(-bef)); document.getElementById('ar').innerText=bvv; }else{ alert("請輸入正整數!"); document.getElementById("bday").value=''; document.getElementById("bday").focus(); } } function aday(){ var atf=document.getElementById("aday").value; if(isInteger(atf)){ var avv=giveDateStr(getTargetday(atf)); document.getElementById('ar').innerText=avv; }else{ alert("請輸入正整數!"); document.getElementById("aday").value=''; document.getElementById("aday").focus(); } } function getTargetday(num){ var number=null; if(num==null||num==0){ number=0; }else{ number=num; } var today=new Date(); var targetday_milliseconds=today.getTime()+1000*60*60*24*number; var targetday=new Date(); targetday.setTime(targetday_milliseconds); //注意,這行是關鍵代碼 return targetday; } function giveDateStr(dd){ var riqiyue=dd.getMonth()+1; var riqihao=dd.getDate(); var riqixingqi=null; if(dd.getDay()=='0'){ xingqi="星期日"; }else if(dd.getDay()=='1'){ xingqi='星期一'; }else if(dd.getDay()=='2'){ xingqi='星期二'; }else if(dd.getDay()=='3'){ xingqi='星期三'; }else if(dd.getDay()=='4'){ xingqi='星期四'; }else if(dd.getDay()=='5'){ xingqi='星期五'; }else if(dd.getDay()=='6'){ xingqi='星期六'; } var riqi=riqiyue+"月"+riqihao+"日"+"("+xingqi+")"; return riqi; } </script> </html>
運行效果如下:
js 日期 獲取今天、昨天、明天第一個函數
function getDay(day){ var today = new Date() // 獲取時間戳(毫秒級) /* day為1,則是,明天的時間戳 day為-1,則是,昨天的時間戳 day為-2,則是,前天的時間戳 */ var targetday_milliseconds = today.getTime() + 1000 * 60 * 60 * 24 * day // Date.setTime(時間戳):設置當前日期的時間 today.setTime(targetday_milliseconds) console.log('today=', today) // today= Sun Mar 05 2023 16:14:56 GMT+0800 (中國標準時間) var tYear = today.getFullYear() // 年 var tMonth = today.getMonth() // 月 var tDate = today.getDate() // 日 tMonth = this.doHandleMonth(tMonth + 1) tDate = this.doHandleMonth(tDate) console.log('返回年月日=', tYear + '-' + tMonth + '-' + tDate) return tYear + '-' + tMonth + '-' + tDate } function doHandleMonth(month) { var m = month if (month.toString().length == 1) { m = '0' + month } return m }
js獲取今天昨天明天的日期第二個函數
/* * @params date 日期 * @params type 日期 prev/current/next 昨天/今天/明天 * @params fmt 日期拼接符 */ function getDays(date, type, fmt) { let currentDate = new Date(date) let y = currentDate.getFullYear() let m = currentDate.getMonth() + 1 let d = currentDate.getDate() function dateFormat(date, fmt) { let y = new Date(date).getFullYear() let m = new Date(date).getMonth() + 1 let d = new Date(date).getDate() return `${y}${fmt}${m}${fmt}$vvxyksv9kd` } switch (type) { case "prev": if (d - 1 < 1) { if (m - 1 < 1) { y = y - 1 m = 12 } else { m = m - 1 } d = new Date(y, m, 0).getDate() } else { d = d - 1 } break case "current": break case "next": if (d + 1 > new Date(y, m, 0).getDate()) { if (m + 1 > 12) { y = y + 1 m = 1 d = 1 } else { m = m + 1 d = 1 } } else { d = d + 1 } break; default: break; } return dateFormat(new Date(`${y}-${m}-$vvxyksv9kd`), fmt) } console.log(getDays(new Date('2021-1-1'), "prev", "-"));
PS:這里再為大家推薦幾款比較實用的天數計算在線工具供大家使用:
在線日期/天數計算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi
在線日期計算器/相差天數計算器:
http://tools.jb51.net/jisuanqi/datecalc
在線日期天數差計算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq
在線天數計算器:
http://tools.jb51.net/jisuanqi/datejsq
更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript時間與日期操作技巧總結》、《JavaScript+HTML5特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關文章
JavaScript之Getters和Setters 平臺支持等詳細介紹
現在,JavaScript的Getters和Setters使用非常廣泛,它和每個JavaScript開發(fā)者的切身利益息息相關,我們先來快速了解什么是Getters和Setters,以及它們?yōu)槭裁春苡杏?然后,我們來看看現在都有哪些平臺支持Gettets和Setters2012-12-12關于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
下面小編就為大家?guī)硪黄P于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06