JS获取日期的方法实例【昨天,今天,明天,前n天,后n天的日期】
发布时间 - 2026-01-11 03:27:23 点击率:次本文实例讲述了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. 日期计算</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 2025 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}${d}`
}
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}-${d}`), fmt)
}
console.log(getDays(new Date('2025-1-1'), "prev", "-"));
PS:这里再为大家推荐几款比较实用的天数计算在线工具供大家使用:
在线日期/天数计算器:
http://tools./jisuanqi/date_jisuanqi
在线日期计算器/相差天数计算器:
http://tools./jisuanqi/datecalc
在线日期天数差计算器:
http://tools./jisuanqi/onlinedatejsq
在线天数计算器:
http://tools./jisuanqi/datejsq
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript时间与日期操作技巧总结》、《JavaScript+HTML5特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# JS
# 日期
# 昨天
# 今天
# 明天
# 前n天
# 后n天
# js获取日期:昨天今天和明天、后天
# 显示今天的日期js代码(阳历和农历)
# js 获取今天以及过去日期
# js获取今天、昨天、明天的日期函数代码
# js获取当前日期昨天、今天、明天日期的不同方法总结
# 则是
# 请输入
# 正整数
# 天之
# 相关内容
# 第一个
# 感兴趣
# 数据结构
# 第二个
# 给大家
# 很简单
# 更多关于
# 再把
# 所述
# 中国
# 几款
# 程序设计
# 这行
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何快速查询网址的建站时间与历史轨迹?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
php485函数参数是什么意思_php485各参数详细说明【介绍】
JavaScript如何操作视频_媒体API怎么控制播放
如何快速搭建个人网站并优化SEO?
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
如何构建满足综合性能需求的优质建站方案?
JavaScript如何实现错误处理_try...catch如何捕获异常?
Laravel Docker环境搭建教程_Laravel Sail使用指南
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
java获取注册ip实例
phpredis提高消息队列的实时性方法(推荐)
如何在IIS中新建站点并解决端口绑定冲突?
如何在IIS7上新建站点并设置安全权限?
如何在万网ECS上快速搭建专属网站?
重庆市网站制作公司,重庆招聘网站哪个好?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
QQ浏览器网页版登录入口 个人中心在线进入
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
进行网站优化必须要坚持的四大原则
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
如何在IIS服务器上快速部署高效网站?
,在苏州找工作,上哪个网站比较好?
如何用免费手机建站系统零基础打造专业网站?
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
如何在宝塔面板创建新站点?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
如何用AI帮你把自己的生活经历写成一个有趣的故事?
Python文件操作最佳实践_稳定性说明【指导】
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
Laravel如何处理文件下载请求?(Response示例)
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
如何用搬瓦工VPS快速搭建个人网站?
活动邀请函制作网站有哪些,活动邀请函文案?
Laravel怎么在Blade中安全地输出原始HTML内容
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
高端云建站费用究竟需要多少预算?

