js获取日期:昨天今天和明天、后天


Posted in Javascript onJune 11, 2014
<html> 
<head> 
<meta http-equiv="Content-Type" content="textml; charset=utf-8"> 
<title>js获取日期:前天、昨天、今天、明天、后天 - Liehuo.Net</title> 
</head> <body> 
<script language="JavaScript" type="text/javascript"> 
function GetDateStr(AddDayCount) { 
var dd = new Date(); 
dd.setDate(dd.getDate()+AddDayCount);//获取AddDayCount天后的日期 
var y = dd.getFullYear(); 
var m = dd.getMonth()+1;//获取当前月份的日期 
var d = dd.getDate(); 
return y+"-"+m+"-"+d; 
} 
document.write("前天:"+GetDateStr(-2)); 
document.write("<br />昨天:"+GetDateStr(-1)); 
document.write("<br />今天:"+GetDateStr(0)); 
document.write("<br />明天:"+GetDateStr(1)); 
document.write("<br />后天:"+GetDateStr(2)); 
document.write("<br />大后天:"+GetDateStr(3)); 
</script> 
</body> 
<ml>

其中有一种方法是:Date.parse(dateVal),此函数功能强大,但是有个致命的缺点,那就是不支持我们常用的“年-月-日”格式,短日期可以使用“/”或“-”作为日期分隔符,但是必须用月/日/年的格式来表示,例如"7/20/96"。

另一种方法是使用 split,比如:

var dtStr = "2006-11-25"; 
var dtArr = dtStr.split("-"); 
var dt = new Date(dtArr[0], dtArr[1], dtArr[2]);

但这种方法较为死板,要求固定的日期格式,只有在没有办法的情况下才用。

如果我们可以将年月日拆分开,就尽量将其拆开,比如 ASP 分别输出年月日。然后用 new Date 来处理,返回的便是日期类型。

日期格式化

<script language="javascript" type="text/javascript"><!-- 
/** 
* 对Date的扩展,将 Date 转化为指定格式的String 
* 月(M)、日(d)、12小时(h)、24小时(H)、分(m)、秒(s)、周(E)、季度(q) 可以用 1-2 个占位符 
* 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) 
* eg: 
* (new Date()).pattern("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423 
* (new Date()).pattern("yyyy-MM-dd E HH:mm:ss") ==> 2009-03-10 二 20:09:04 
* (new Date()).pattern("yyyy-MM-dd EE hh:mm:ss") ==> 2009-03-10 周二 08:09:04 
* (new Date()).pattern("yyyy-MM-dd EEE hh:mm:ss") ==> 2009-03-10 星期二 08:09:04 
* (new Date()).pattern("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18 
*/ 
Date.prototype.pattern=function(fmt) { 
var o = { 
"M+" : this.getMonth()+1, //月份 
"d+" : this.getDate(), //日 
"h+" : this.getHours()%12 == 0 ? 12 : this.getHours()%12, //小时 
"H+" : this.getHours(), //小时 
"m+" : this.getMinutes(), //分 
"s+" : this.getSeconds(), //秒 
"q+" : Math.floor((this.getMonth()+3)/3), //季度 
"S" : this.getMilliseconds() //毫秒 
}; 
var week = { 
"0" : "\u65e5", 
"1" : "\u4e00", 
"2" : "\u4e8c", 
"3" : "\u4e09", 
"4" : "\u56db", 
"5" : "\u4e94", 
"6" : "\u516d" 
}; 
if(/(y+)/.test(fmt)){ 
fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length)); 
} 
if(/(E+)/.test(fmt)){ 
fmt=fmt.replace(RegExp.$1, ((RegExp.$1.length>1) ? (RegExp.$1.length>2 ? "\u661f\u671f" : "\u5468") : "")+week[this.getDay()+""]); 
} 
for(var k in o){ 
if(new RegExp("("+ k +")").test(fmt)){ 
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length))); 
} 
} 
return fmt; 
} var date = new Date(); 
window.alert(date.pattern("yyyy-MM-dd hh:mm:ss")); 
// --></script>
Javascript 相关文章推荐
javascript下arguments,caller,callee,call,apply示例及理解
Dec 24 Javascript
jquery图片切换实例分析
Apr 15 Javascript
JS+CSS实现简易的滑动门效果代码
Sep 24 Javascript
jquery实现可自动判断位置的弹出层效果代码
Oct 12 Javascript
扩展Bootstrap Tooltip插件使其可交互的方法
Nov 07 Javascript
vue2.0 keep-alive最佳实践
Jul 06 Javascript
vue引入swiper插件的使用实例
Jul 19 Javascript
详解从Vue.js源码看异步更新DOM策略及nextTick
Oct 11 Javascript
在vue中,v-for的索引index在html中的使用方法
Mar 06 Javascript
解决koa2 ctx.render is not a function报错问题
Aug 07 Javascript
vue中音频wavesurfer.js的使用方法
Feb 20 Vue.js
webpack 如何同时输出压缩和未压缩的文件的实现步骤
Jun 05 Javascript
js使用栈来实现10进制转8进制与取除数及余数
Jun 11 #Javascript
删除javascript中注释语句的正则表达式
Jun 11 #Javascript
Jquery自定义button按钮的几种方法
Jun 11 #Javascript
教你用jquery实现iframe自适应高度
Jun 11 #Javascript
浅析jQuery中调用ajax方法时在不同浏览器中遇到的问题
Jun 11 #Javascript
控制文字内容的显示与隐藏示例
Jun 11 #Javascript
用js一次改变多个input的readonly属性值的方法
Jun 11 #Javascript
You might like
php去除字符串换行符示例分享
2014/02/13 PHP
thinkphp3.2.3版本的数据库增删改查实现代码
2016/09/22 PHP
Laravel5.1框架路由分组用法实例分析
2020/01/04 PHP
js网页版计算器的简单实现
2013/07/02 Javascript
jquery不常用方法汇总
2015/07/26 Javascript
js编写当天简单日历效果【实现代码】
2016/05/03 Javascript
Nodejs全局安装和本地安装的不同之处
2016/07/04 NodeJs
JS遍历页面所有对象属性及实现方法
2016/08/01 Javascript
Bootstrap Modal遮罩弹出层(完整版)
2016/11/21 Javascript
ComboBox(下拉列表框)通过url加载调用远程数据的方法
2017/08/06 Javascript
Vue.js实现网格列表布局转换方法
2017/08/25 Javascript
vue实现图片加载完成前的loading组件方法
2018/02/05 Javascript
Vue封装一个简单轻量的上传文件组件的示例
2018/03/21 Javascript
解决Vue中mounted钩子函数获取节点高度出错问题
2018/05/18 Javascript
vue自定义移动端touch事件之点击、滑动、长按事件
2018/07/10 Javascript
解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
2018/08/24 Javascript
利用Node.js如何实现文件循环覆写
2019/04/05 Javascript
NodeJs生成sitemap站点地图的方法示例
2019/06/11 NodeJs
[02:18]DOTA2英雄基础教程 育母蜘蛛
2014/01/20 DOTA
在Python中使用zlib模块进行数据压缩的教程
2015/06/26 Python
浅谈Python的垃圾回收机制
2016/12/17 Python
解决已经安装requests,却依然提示No module named requests问题
2018/05/18 Python
Python 迭代,for...in遍历,迭代原理与应用示例
2019/10/12 Python
Mac 使用python3的matplot画图不显示的解决
2019/11/23 Python
python属于解释型语言么
2020/06/15 Python
css3 图片圆形显示 如何CSS将正方形图片显示为圆形图片布局
2014/10/10 HTML / CSS
豆腐の盛田屋官网:日本自然派的豆乳面膜、肥皂、化妆水、乳液等
2016/10/08 全球购物
奥兰多迪士尼门票折扣:Undercover Tourist
2018/07/09 全球购物
策划助理岗位职责
2013/11/18 职场文书
大专生自我评价
2014/01/28 职场文书
化工专业求职信
2014/07/01 职场文书
生产车间主任岗位职责
2015/04/08 职场文书
四十年同学聚会致辞
2015/07/28 职场文书
2016幼儿教师自荐信范文
2016/01/28 职场文书
小学二年级语文教学反思
2016/03/03 职场文书
健身房被搭讪?用python写了个小米计时器助人为乐
2021/06/08 Python