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 相关文章推荐
js 鼠标点击事件及其它捕获
Jun 04 Javascript
Javascript延迟执行实现方法(setTimeout)
Dec 30 Javascript
jquery中添加属性和删除属性
Jun 03 Javascript
jQuery 3.0十大新特性最终版发布
Jul 14 Javascript
javaScript 事件绑定、事件冒泡、事件捕获和事件执行顺序整理总结
Oct 10 Javascript
微信小程序教程系列之视图层的条件渲染(10)
Apr 19 Javascript
Angularjs的$http异步删除数据详解及实例
Jul 27 Javascript
对于Javascript 执行上下文的全面了解
Sep 05 Javascript
webpack组织模块打包Library的原理及实现
Mar 10 Javascript
Vue路由钩子之afterEach beforeEach的区别详解
Jul 15 Javascript
深度解读vue-resize的具体用法
Jul 08 Javascript
openlayers实现地图弹窗
Sep 25 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连接SQLServer2005 的问题解决方法
2010/07/19 PHP
php判断两个浮点数是否相等的方法
2015/03/14 PHP
老生常谈PHP中的数据结构:DS扩展
2017/07/17 PHP
PHP实现本地图片转base64格式并上传
2020/05/29 PHP
javascript-TreeView父子联动效果保持节点状态一致
2007/08/12 Javascript
javascript中将Object转换为String函数代码 (json str)
2012/04/29 Javascript
javascript页面倒计时实例
2015/07/25 Javascript
javascript实现手机震动API代码
2015/08/05 Javascript
基于Jquery制作图片文字排版预览效果附源码下载
2015/11/18 Javascript
使用node+vue.js实现SPA应用
2016/01/28 Javascript
原生js实现水平方向无缝滚动
2017/01/10 Javascript
微信小程序开发图片拖拽实例详解
2017/05/05 Javascript
Vue.js devtool插件安装后无法使用的解决办法
2017/11/27 Javascript
vue+Element-ui实现分页效果实例代码详解
2018/12/10 Javascript
nodeJS进程管理器pm2的使用
2019/01/09 NodeJs
微信小程序访问豆瓣电影api的实现方法
2019/03/31 Javascript
[12:51]71泪洒现场!是DOTA2让经典重现
2014/03/24 DOTA
[51:17]Mski vs VGJ.S Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
Python计算程序运行时间的方法
2014/12/13 Python
Python通过90行代码搭建一个音乐搜索工具
2015/07/29 Python
python运行其他程序的实现方法
2017/07/14 Python
Python正则表达式非贪婪、多行匹配功能示例
2017/08/08 Python
python中数据爬虫requests库使用方法详解
2018/02/11 Python
对python多线程中互斥锁Threading.Lock的简单应用详解
2019/01/11 Python
python基础梳理(一)(推荐)
2019/04/06 Python
python3实现弹弹球小游戏
2019/11/25 Python
Django添加bootstrap框架时无法加载静态文件的解决方式
2020/03/27 Python
Django更新models数据库结构步骤
2020/04/01 Python
字中字效果的实现【html5实例】
2016/05/03 HTML / CSS
梅西酒窖:Macy’s Wine Cellar
2018/01/07 全球购物
伦敦著名的运动鞋综合商店:Footpatrol
2019/03/25 全球购物
计算机开发个人求职信范文
2013/09/26 职场文书
坚定理想信念心得体会
2014/03/11 职场文书
党员查摆问题及整改措施
2014/10/10 职场文书
初婚初育证明范本
2014/11/24 职场文书
mysql死锁和分库分表问题详解
2021/04/16 MySQL