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实现拼音排序的方法
Nov 20 Javascript
jquery select 设置默认选中的示例代码
Feb 07 Javascript
js如何调用qq互联api实现第三方登录
Mar 28 Javascript
原生javascript实现DIV拖拽并计算重复面积
Jan 02 Javascript
解决jquery实现的radio重新选中的问题
Jul 03 Javascript
JavaScript数据结构之广义表的定义与表示方法详解
Apr 12 Javascript
Angular2使用Angular-CLI快速搭建工程(二)
May 21 Javascript
JavaScript插件Tab选项卡效果
Nov 14 Javascript
简单通过settimeout看javascript的运行机制
May 10 Javascript
webpack自动打包和热更新的实现方法
Jun 24 Javascript
JSON stringify方法原理及实例解析
Oct 23 Javascript
vue实现input输入模糊查询的三种方式
Aug 14 Vue.js
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中将时间差转换为字符串提示的实现代码
2011/08/08 PHP
比file_get_contents稳定的curl_get_contents分享
2012/01/11 PHP
php利用单例模式实现日志处理类库
2014/02/10 PHP
PHP实现的MongoDB数据库操作类分享
2014/05/12 PHP
如何使用jQuery+PHP+MySQL来实现一个在线测试项目
2015/04/26 PHP
PHP PDOStatement::closeCursor讲解
2019/01/30 PHP
laravel框架数据库配置及操作数据库示例
2019/10/10 PHP
锋利的jQuery 要点归纳(一) jQuery选择器
2010/03/21 Javascript
JavaScript实现网页图片等比例缩放实现代码及调用方式
2013/02/25 Javascript
JavaScrip实现PHP print_r的数功能(三种方法)
2013/11/12 Javascript
JavaScript中自定义事件用法分析
2014/12/23 Javascript
jQuery的css()方法用法实例
2014/12/24 Javascript
JS实现点击复选框将按钮或文本框变为灰色不可用的方法
2015/08/11 Javascript
javascript实现动态标签云
2015/10/16 Javascript
用nodejs的实现原理和搭建服务器(动态)
2016/08/10 NodeJs
探索Vue.js component内容实现
2016/11/03 Javascript
JS中SetTimeout和SetInterval使用初探
2017/03/23 Javascript
angular框架实现全选与单选chekbox的自定义
2017/07/06 Javascript
详解最新vue-cli 2.9.1的webpack存在问题
2017/12/16 Javascript
微信小程序JS加载esmap地图的实例详解
2019/09/04 Javascript
layui异步加载table表中某一列数据的例子
2019/09/16 Javascript
解决vue+ element ui 表单验证有值但验证失败问题
2020/01/16 Javascript
微信小程序实现树莓派(raspberry pi)小车控制
2020/02/12 Javascript
python 根据正则表达式提取指定的内容实例详解
2016/12/04 Python
python difflib模块示例讲解
2017/09/13 Python
python set内置函数的具体使用
2019/07/02 Python
关于PyTorch 自动求导机制详解
2019/08/18 Python
python实现三壶谜题的示例详解
2020/11/02 Python
html5 canvas实现跟随鼠标旋转的箭头
2016/03/11 HTML / CSS
英国豪华家具和经典家居饰品购物网站:OKA
2020/06/05 全球购物
美容院经理岗位职责
2014/04/03 职场文书
《永远的白衣战士》教学反思
2014/04/25 职场文书
2014镇党委班子对照检查材料思想汇报
2014/09/23 职场文书
工作汇报开头与结尾怎么写
2014/11/08 职场文书
秋季运动会开幕词
2015/01/28 职场文书
JavaScript阻止事件冒泡的方法
2021/12/06 Javascript