本文实例讲述了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.jb51.net 日期计算</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 = /^\+"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>
运行效果如下:
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程序设计有所帮助。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 群星《2024好听新歌36》AI调整音效【WAV分轨】
- 梁朝伟.1986-朦胧夜雨裡(华星40经典)【华星】【WAV+CUE】
- 方芳.1996-得意洋洋【中唱】【WAV+CUE】
- 辛欣.2001-放120个心【上海音像】【WAV+CUE】
- 柏菲·万山红《花开原野1》限量开盘母带ORMCD[低速原抓WAV+CUE]
- 柏菲·万山红《花开原野2》限量开盘母带ORMCD[低速原抓WAV+CUE]
- 潘安邦《思念精选集全纪录》5CD[WAV+CUE]
- 杨千嬅《千嬅新唱金牌金曲》金牌娱乐 [WAV+CUE][985M]
- 杨钰莹《依然情深》首版[WAV+CUE][1G]
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】