js脚本的日期操作


js脚本的日期操作

为这个js操作日期的事情,郁闷了好些时间,本人基础太弱,只能靠google。时间对象是一个我们常要用到的对象,不管是时间输出还是时间判断等操作。在VbScript中有许多时间对象非常好用,下面记录一部分:
时间对象是一个内置对象,而不是其它对象的属性,允许用户执行各种使用日期和时间的过程。方法可分为得到时间、设置时间和转换时间。
得到时间的方法:

getDate()    //查看Date对象并返回日期
getDay()    //返回星期几
getHours()    //返回小时数
getMinutes()    //返回分钟数
getMonth()    //返回月份值
getSeconds()    //返回秒数
getTime()    //返回完整的时间
getYear()    //返回年份

设置时间的方法:

setDate()    //改变Date对象的日期
setHours()    //改变小时数
setMinutes()    //改变分钟数
setMonth()    //改变月份
setSeconds()    //改变秒数
setTime()    //改变完整的时间
setYear()    //改变年份

转换时间的方法:

toGMTString() 把Date对象的日期(一个数值)转变成一个GMT时间字符串,返回类似下面的值:Weds,14 May 2007 10:02:02 GMT(精确的格式依赖于计算机上所运行的操作系统而变)
toLocaleString() 把Date对象的日期(一个数值)转变成一个字符串,使用所在计算机上配置使用的特定日期格式
UTC() 使用Date UTC(年、月、日、时、分、秒),以自从1997年1月1日00:00:00(其中时、分、秒是可选的)以来的毫秒数的形式返回日期
几个需要注意的地方:

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

<script language="javascript">
d = new Date();
alert(d.toLocaleString());
d.setDate(14);
alert(d.toLocaleString());
d.setYear(2007);
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>

5、数字日期转汉字

<html>  
<head>  
<title>ctusky.com数字日期转换演示</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()+"日";  
temptemp = temp.replace(/(/d)(/d)/g,"$1十$2").replace(/1十/g,"十").replace(/十0/g,"十");  
returnValue += temp;  
returnValuereturnValue = returnValue.replace(//d/g, function(sts){return values[parseInt(sts)]});  
return returnValue;  
}  
 
var t=new Date();  
document.write(t.getRead());  
</script>  
</body>  
</html>

6、得到前N天或后N天的日期
方法1:

<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>

方法2:

<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>

方法3:

<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>

依旧是用过的东西记下来,这样才有点帮助。完稿。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值