javascript日期操作

时间对象是一个我们经常要用到的对象,无论是做时间输出、时间判断等操作时都与这个对象离不开。它是一个内置对象。

IE8不支持new Date("2016-3-28")这种格式的日期声明方式,如果使用会提示NaN。可以使用new Date(year, month, day)这种方式代替。注意其中month范围是0~11。

在网上找到一段代码,用来格式化时间的。

An Extended ISO 8601 local Date format YYYY-MM-DD can be parsed to a Date with the following:
function parseISO8601(dateStringInRange) {
  var isoExp = /^\s*(\d{4})-(\d\d)-(\d\d)\s*$/,
  date = new Date(NaN),
  month,
  parts = isoExp.exec(dateStringInRange);
  if(parts) {
    month = +parts[2];
    date.setFullYear(parts[1], month - 1, parts[3]);
    if(month != date.getMonth() + 1) {
    date.setTime(NaN);
  }
}
return date;
}

方法:分为得到时间方法、设置时间方法和转换时间方法 得到时间方法

几个需要注意的地方:

1、得到日期和年和设置日期和年时间,其中很怪的问题就是不能对月份进行设置(比较的怪):

<script language="javascript">
d = new Date();
alert(d.toLocaleString());
d.setDate(25);
alert(d.toLocaleString());
d.setYear(2000);
alert(d.toLocaleString());
</script>

2、获得年的时候最好用getFullYear()方法来做
3、由于针对月份,JS是从0开始的,因此需要对月份进行操作时要加1

下面是几个关于时间的经典而且经常会用到的例子,希望对大家会有提高的。

1、将2005-8-5转换成2005-08-05格式

<script language="javascript">
var strDate = '2005-8-5';
window.alert(strDate.replace(/\b(\w)\b/g, '0$1'));
</script>

2、得到间隔天数

<script type="text/javascript">
<!--
alert("间隔天数为:"+(new Date('2005/8/15')-new Date('2003/9/18'))/1000/60/60/24+"天")
-->
</script>

3、得到间隔时间

<script>
var d1=new Date("2004/09/16 20:08:00");
var d2=new Date("2004/09/16 10:18:03");
var d3=d1-d2;
var h=Math.floor(d3/3600000);
var m=Math.floor((d3-h*3600000)/60000);
var s=(d3-h*3600000-m*60000)/1000;
alert("相差"+h+"小时"+m+"分"+s+"秒");
</script>

4、得到今天的日期

<script language="javascript">
d = new Date();
alert(d.getFullYear()+"年"+(d.getMonth()+1)+"月"+d.getDate()+"日");
</script>

6、数字日期转汉字

<html>
<head>
<title> New Document </title>
</head>
<body>
<script language=javascript>
Date.prototype.getRead = function() {
var values = new Array("零", "一", "二", "三", "四", "五", "六", "七", "八", "九");
var returnValue, temp;
returnValue = this.getYear()+"年";
temp = (this.getMonth()+1)+"月"+this.getDate()+"日";
temp = temp.replace(/(\d)(\d)/g,"$1十$2").replace(/1十/g,"十").replace(/十0/g,"十");
returnValue += temp;
returnValue = returnValue.replace(/\d/g, function(sts){
return values[parseInt(sts)]
});
return returnValue;
}
var t=new Date();
document.write(t.getRead());
</script>
</body>
</html>

7、得到前N天或后N天的日期
方法一:

<script type="text/javascript">
function showdate(n) {
var uom = new Date(new Date()-0+n*86400000);
uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate();
return uom;
}
window.alert("今天是:"+showdate(0));
window.alert("昨天是:"+showdate(-1));
window.alert("明天是:"+showdate(1));
window.alert("10天前是:"+showdate(-10));
window.alert("5天后是:"+showdate(5));
</script>

方法二:

<script type="text/javascript">
function showdate(n) {
var uom = new Date();
uom.setDate(uom.getDate()+n);
uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate();
return uom;
}
window.alert("今天是:"+showdate(0));
window.alert("昨天是:"+showdate(-1));
window.alert("明天是:"+showdate(1));
window.alert("10天前是:"+showdate(-10));
window.alert("5天后是:"+showdate(5));
</script>

方法三:

<script language="Javascript">
Date.prototype.getDays=function(){
var _newDate=new Date();
_newDate.setMonth(_newDate.getMonth()+1);
_newDate.setDate(0);
$_days=_newDate.getDate();
delete _newDate;
return $_days;
}
function showdate(n) {
var uom = new Date();
uom.setDate(uom.getDate()+n);
uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate()+"\n星期"+('天一二三四五六'.charAt(uom.getDay()))+"\n本月有"+ uom.getDays()+"天";
return uom;
}
window.alert("今天是:"+showdate(0));
window.alert("昨天是:"+showdate(-1));
window.alert("明天是:"+showdate(1));
window.alert("10天前是:"+showdate(-10));
window.alert("5天后是:"+showdate(5));
</script>

javascript对日期处理的常用方法类

<script language="JavaScript">
<!--

//程序:常用公历日期处理程序

/*
*  用相对不规则的字符串来创建日期对象,
*  不规则的含义为:顺序包含年月日三个数值串,有间隔
*/
String.prototype.parseDate=function(){
  var ar=(this+",0,0,0").match(/d+/g);
  return ar[5] ? (new Date(ar[0],ar[1]-1,ar[2],ar[3],ar[4],ar[5])) : (new Date());
}

/*
*  功能:根据输入表达式返回日期字符串
*  参数:dateFmt:字符串,由以下结构组成
*  yy:长写年,YY:短写年mm:数字月,MM:英文月,dd:日,hh:时,
*  mi:分,ss秒,ms:毫秒,we:汉字星期,WE:英文星期.
*  isFmtWithZero:是否用0进行格式化,true or false
*  返回:对应日期的中文字符串
*/
Date.prototype.toString=function(dateFmt, isFmtWithZero){
  dateFmt=(dateFmt==null ? "yy-mm-dd hh:mi:ss" : dateFmt);
  if(typeof(dateFmt)!="string")
  throw(newError(-1,'toString()方法的第一个参数为字符串类型!'));
  isFmtWithZero=!!isFmtWithZero;
  var weekArr=[["日","一","二","三","四","五","六"], ["SUN","MON","TUR","WED","THU","FRI","SAT"]];
  var monthArr=["JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"];    var str=dateFmt;
  var o={
    "yy":this.getFullYear(),
    "YY":this.getYear(),
    "mm":this.getMonth()+1,
    "MM":monthArr[this.getMonth()],
    "dd":this.getDate(),
    "hh":this.getHours(),
    "mi":this.getMinutes(),
    "ss":this.getSeconds(),
    "we":"星期"+weekArr[0][this.getDay()],
    "WE":weekArr[1][this.getDay()]
  }
  for(var i in o){
    str=str.replace(newRegExp(i,"g"),o[i].toString().fmtWithZero(isFmtWithZero));
  }
  str=str.replace(/ms/g,this.getMilliseconds().toString().fmtWithZeroD(isFmtWithZero));
  return str;
}

/*
*  将一位数字格式化成两位,如:9 to 09
*/
String.prototype.fmtWithZero=function(isFmtWithZero){
  //正则表达式中^表示开始,$表示结束,d表示数字
  return (isFmtWithZero && /^d$/.test(this)) ? "0"+this : this;
}
String.prototype.fmtWithZeroD=function(isFmtWithZero){
  //此处应为补齐三位
  return (isFmtWithZero && /^d{2}$/.test(this)) ? "0"+this : ( (isFmtWithZero && /^d$/.test(this)) ? "00"+this : this);
}

/*功能:返回与某日期相距N天(N个24小时)的日期*参数:numnumber类型可以为正负整数或者浮点数,默认为1;
*  type0(秒)or1(天),默认为天
*  返回:新的Date对象
*/
Date.prototype.dateAfter=function(num,type){
num=(num==null?1:num);
if(typeof(num)!="number")
throw new Error(-1,"dateAfterDays(num,type)的num参数为数值类型.");
type=(type==null?1:type);
var arr=[1000,86400000];
returnnewDate(this.valueOf()+num*arr[type]);}

//判断是否是闰年,返回true或者false
Date.prototype.isLeapYear=function(){
var year=this.getFullYear();
return(0==year%4&&((year%100!=0)||(year%400==0)));
}

//返回该月天数Date.prototype.getDaysOfMonth=function(){
return(newDate(this.getFullYear(),this.getMonth()+1,0)).getDate();
}

//日期比较函数,参数date:为Date类型,如this日期晚于参数:1,相等:0早于:-1
Date.prototype.dateCompare=function(date){
  if(typeof(date)!="object"||!(/Date/.test(date.constructor)))
    thrownewError(-1,"dateCompare(date)的date参数为Date类型.");
  var d=this.getTime()-date.getTime();
  return d>0?1:(d==0?0:-1);
}

/*功能:返回两日期之差*参数:pd PowerDate对象
*  type:返回类别标识.yy:年,mm:月,ww:周,dd:日,hh:小时,mi:分,ss:秒,ms:毫秒*  intOrFloat:返回整型还是浮点型值0:整型,不等于0:浮点型
*  output:输出提示,如:时间差为#周!
*/
Date.prototype.calDateDistance=function(date,type,intOrFloat,output){
  if( typeof(date) != "object" || !(/Date/.test(date.constructor)))
    thrownewError(-1,"calDateDistance(date,type,intOrFloat)的date参数为Date类型.");
  type=(type==null?'dd':type);
  if(!((newRegExp(type+",","g")).test("yy,mm,ww,dd,hh,mi,ss,ms,")))
    thrownewError(-1,"calDateDistance(pd,type,intOrFloat,output)的type参数为非法.");
  variof=(intOrFloat==null?0:intOrFloat);
  varnum=0;
  varo={
    "ww":7*86400000,
    "dd":86400000,
    "hh":3600000,
    "mi":60000,
    "ss":1000,
    "ms":1
  }
  switch(type){
    case"yy":num=this.getFullYear()-date.getFullYear();break;
    case"mm":num=(this.getFullYear()-date.getFullYear())*12+this.getMonth()-date.getMonth();break;
    default:      varsub=this.valueOf()-date.valueOf();      if(o[type])        num=(sub/o[type]).fmtRtnVal(iof);      break;
  }
  return(output?output.replace(/#/g,""+num+""):num);
}

//返回整数或者两位小数的浮点数Number.prototype.fmtRtnVal=function(intOrFloat)
{
return(intOrFloat==0?Math.floor(this):parseInt(this*100)/100);
}

//根据当前日期所在年和周数返回周日的日期Date.prototype.RtnByWeekNum=function(weekNum){
if(typeof(weekNum)!="number")    thrownewError(-1,"RtnByWeekNum(weekNum)的参数是数字类型.");  vardate=newDate(this.getFullYear(),0,1);
varweek=date.getDay();
week=(week==0?7:week);
returndate.dateAfter(weekNum*7-week,1);}

//根据日期返回该日期所在年的周数
Date.prototype.getWeekNum=function(){
vardat=newDate(this.getFullYear(),0,1);
varweek=dat.getDay();
week=(week==0?7:week);
vardays=this.calDateDistance(dat,"dd")+1;
return((days+6-this.getDay()-7+week)/7);}
//-->
</script>
<script language="JavaScript">
<!--
var dw=document.write;
var date2="2005-12-30".parseDate();
dw(date2,"<br>");
vardate3="2006-1-10111111".parseDate();
dw(date2.calDateDistance(date3,null,null,"时间差为#天!"));
//alert(newDate(2000,2,-29));
//
-->
</script>

字符串转日期

function toDate(str){
    var sd=str.split("-");
    return new Date(sd[0],sd[1],sd[2]);
}
//在IE8以下是不支持的
function toDate(str){
    return new Date(str);
}

比较日期大小

var d1=toDate("2001-2-2 ");
var d2=toDate("2001-2-3");
alert(d1>d2);

获取两日期月份之差

var diff = (date1. getFullYear() - date2.getFullYear()) * 12
               + date1.getMonth() - date2.getMonth();
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,936评论 6 13
  • SwiftDate概况 从Swift发布起,我们就没有放弃使用Swift。 当然,我们希望在项目能够轻松自如地管理...
    Mee_Leo阅读 10,047评论 1 13
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,605评论 18 399
  • 侧脸 鞋带 善良的上衣口袋 那么自然 那么自在 清新 直白 月亮之外 那么简单的你 那么简单的存在 2014.05.01
    杨戏水阅读 2,606评论 10 6
  • 非原创…酥死啦 1 我认识一个女孩,我们都叫她“小野猫”。小野猫很爱玩,有事没事都爱出去喝两杯,换男朋友速度更是和...
    小金鱼是小仙女吖阅读 458评论 0 1