整理一些JavaScript时间处理扩展函数

在JavaScript中,时间处理是经常需要用到的。最近想要慢慢建立自己的代码库,整理了几个之前用到的js处理时间的函数,发出来跟大家分享一下,以后的使用中会不断增加和修改代码库。

把字符串转换为日期对象

有时需要把字符串转换为日期对象,但是IE下不支持new Date("2011-04-07")这样实例化日期对象,ff下支持,所以写了一个扩展函数,用来把形如yyyy-mm-dd或者dd/mm/yyyy的字符串转换为日期对象。代码如下:兰西县璩家摄影

/*
函数:把字符串转换为日期对象
参数:yyyy-mm-dd或dd/mm/yyyy形式的字符串
返回:Date对象
注:IE下不支持直接实例化日期对象,如new Date("2011-04-06")
*/
Date.prototype.convertDate = function (date)
{
	var flag = true;
	var dateArray = date.split("-");
	if (dateArray.length != 3)
	{
		dateArray = date.split("/");
		if (dateArray.length != 3)
		{
			return null;
		}
		flag = false;
	}
	var newDate = new Date();
	if (flag)
	{
		// month从0开始
		newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);
	}
	else
	{
		newDate.setFullYear(dateArray[2], dateArray[1] - 1, dateArray[0]);
	}
	newDate.setHours(0, 0, 0);
	return newDate;
};

测试:

<script type="text/javascript">
  document.writeln(new Date().convertDate("7/12/2011"));
</script>

输出:Wed Dec 07 2011 17:30:58 GMT+0800

计算两个日期之间的差值

这个函数可以计算两个日期之前的差值(毫秒/秒/分/小时/天),主要用到了getTime()函数和Math.floor()函数,代码如下:

/*
函数:计算两个日期之间的差值
参数:date是日期对象
	flag:ms-毫秒,s-秒,m-分,h-小时,d-天,M-月,y-年
返回:当前日期和date两个日期相差的毫秒/秒/分/小时/天
*/
Date.prototype.dateDiff = function (date, flag)
{
	var msCount;
	var diff = this.getTime() - date.getTime();
	switch (flag)
	{
		case "ms":
			msCount = 1;
			break;
		case "s":
			msCount = 1000;
			break;
		case "m":
			msCount = 60 * 1000;
			break;
		case "h":
			msCount = 60 * 60 * 1000;
			break;
		case "d":
			msCount = 24 * 60 * 60 * 1000;
			break;
	}
	return Math.floor(diff / msCount);
};

测试:

<script type="text/javascript">
  var d1 = new Date().convertDate("2011-04-08");
  var d2 = new Date().convertDate("2011-04-07");
  document.writeln(d1.dateDiff(d2, ‘d‘));
</script>

判断一个年份是否为闰年

 /*
函数:判断一个年份是否为闰年
返回:是否为闰年
*/
Date.prototype.isLeapYear = function ()
{
	var year = this.getFullYear();
	return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);
}

测试:

<script type="text/javascript">
  document.writeln(new Date().convertDate("2000-04-08").isLeapYear() + " ");
  document.writeln(new Date().convertDate("2011-04-08").isLeapYear() + " ");
</script>
// 结果:
// true
// false

格式化日期

这个函数是从网上搜来的,稍微修改了一下,它类似.net中Format函数,传入格式化字符串如"yyyy-MM-dd",返回格式化后的日期。

/*
函数:格式化日期
参数:formatStr-格式化字符串
	d:将日显示为不带前导零的数字,如1
	dd:将日显示为带前导零的数字,如01
	ddd:将日显示为缩写形式,如Sun
	dddd:将日显示为全名,如Sunday
	M:将月份显示为不带前导零的数字,如一月显示为1
	MM:将月份显示为带前导零的数字,如01
	MMM:将月份显示为缩写形式,如Jan
	MMMM:将月份显示为完整月份名,如January
	yy:以两位数字格式显示年份
	yyyy:以四位数字格式显示年份
	h:使用12小时制将小时显示为不带前导零的数字,注意||的用法
	hh:使用12小时制将小时显示为带前导零的数字
	H:使用24小时制将小时显示为不带前导零的数字
	HH:使用24小时制将小时显示为带前导零的数字
	m:将分钟显示为不带前导零的数字
	mm:将分钟显示为带前导零的数字
	s:将秒显示为不带前导零的数字
	ss:将秒显示为带前导零的数字
	l:将毫秒显示为不带前导零的数字
	ll:将毫秒显示为带前导零的数字
	tt:显示am/pm
	TT:显示AM/PM
	返回:格式化后的日期
*/
Date.prototype.format = function (formatStr)
{
	var date = this;
	/*
	函数:填充0字符
	参数:value-需要填充的字符串, length-总长度
	返回:填充后的字符串
	*/
	var zeroize = function (value, length)
	{
		if (!length)
		{
			length = 2;
		}
		value = new String(value);
		for (var i = 0, zeros = ‘‘; i < (length - value.length); i++)
		{
			zeros += ‘0‘;
		}
		return zeros + value;
	};
	return formatStr.replace(/"[^"]*"|‘[^‘]*‘|\b(?:d{1,4}|M{1,4}|yy(?:yy)?|([hHmstT])\1?|[lLZ])\b/g, function($0)
	{
		switch ($0)
		{
			case ‘d‘: return date.getDate();
			case ‘dd‘: return zeroize(date.getDate());
			case ‘ddd‘: return [‘Sun‘, ‘Mon‘, ‘Tue‘, ‘Wed‘, ‘Thr‘, ‘Fri‘, ‘Sat‘][date.getDay()];
			case ‘dddd‘: return [‘Sunday‘, ‘Monday‘, ‘Tuesday‘, ‘Wednesday‘, ‘Thursday‘, ‘Friday‘, ‘Saturday‘][date.getDay()];
			case ‘M‘: return date.getMonth() + 1;
			case ‘MM‘: return zeroize(date.getMonth() + 1);
			case ‘MMM‘: return [‘Jan‘, ‘Feb‘, ‘Mar‘, ‘Apr‘, ‘May‘, ‘Jun‘, ‘Jul‘, ‘Aug‘, ‘Sep‘, ‘Oct‘, ‘Nov‘, ‘Dec‘][date.getMonth()];
			case ‘MMMM‘: return [‘January‘, ‘February‘, ‘March‘, ‘April‘, ‘May‘, ‘June‘, ‘July‘, ‘August‘, ‘September‘, ‘October‘, ‘November‘, ‘December‘][date.getMonth()];
			case ‘yy‘: return new String(date.getFullYear()).substr(2);
			case ‘yyyy‘: return date.getFullYear();
			case ‘h‘: return date.getHours() % 12 || 12;
			case ‘hh‘: return zeroize(date.getHours() % 12 || 12);
			case ‘H‘: return date.getHours();
			case ‘HH‘: return zeroize(date.getHours());
			case ‘m‘: return date.getMinutes();
			case ‘mm‘: return zeroize(date.getMinutes());
			case ‘s‘: return date.getSeconds();
			case ‘ss‘: return zeroize(date.getSeconds());
			case ‘l‘: return date.getMilliseconds();
			case ‘ll‘: return zeroize(date.getMilliseconds());
			case ‘tt‘: return date.getHours() < 12 ? ‘am‘ : ‘pm‘;
			case ‘TT‘: return date.getHours() < 12 ? ‘AM‘ : ‘PM‘;
		}
	});
}

测试:

<script type="text/javascript">
  document.writeln(new Date().format("yyyy-MM-dd hh:mm:ss"));
</script>
// 结果:
// 2011-04-08 10:13:37
时间: 2024-10-15 12:39:07

整理一些JavaScript时间处理扩展函数的相关文章

javascript 时间操作

javascript时间函数 javascript提供了Date对象来进行时间和日期的计算.Date对象有多种构造函数: 1.dateObj=new Date() //当前时间 2.dateObj=new Date(milliseconds) //距离起始时间1970年1月1日的毫秒数 3.dateObj=new Date(datestring) //字符串代表的日期与时间.此字符串可以使用Date.parse()转换,比如"Jannuary 1, 1998 20:13:15" 4.d

未整理--第一次缓冲时间

详解FirstBufferTime 测试结果分析过程中,经常遇到第一次缓冲时间FirstBufferTime,并且发现大部分系统的响应时间也都浪费在了这里,再给研发解释这个问题时候,又不能拿FirstBufferTime直接给研发说,抽时间整理了下,希望对大家有用 以下资料来自 LR帮助手册: 定义:第一次缓冲时间细分图显示成功从Web服务器返回的第一次缓冲之前的这一段时间内,每个网页组件的相关服务器/网络时间(以秒为单位) 网络时间:从发送第一个http请求那一刻直到收到确认为止,所经过的平均

ubuntu常用命令总结(整理好长时间所得)

1.df命令 # df -ha 显示所有的档案以及分区的使用情况 # df -h /dev/sda1 显示sda1的磁盘使用情况 # df -T 显示每个分区的所属的档案系统名称,也会显示分区的格式类型(比如ext3) 注:h参数表示转换为M,G等人们常用的磁盘空间单位显示 2.du命令 # du -h src 显示src目录中各个文件(或者文件)所占用的磁盘空间 # du -hs /usr 显示usr目录中所有文件的总大小 # du -h test.c 显示test.c文件所占用的磁盘空间 3

JavaScript 时间显示

<span id="localtime"><span> <script type="text/javascript"> function showLocalTime(OID) { window.setTimeout(function(){ var today = new Date(), arr = new Array('日', '一', '二', '三', '四', '五', '六'), yy = today.getYear(),

Javascript 时间计算函数

Javascript 时间计算函数 <span style="font-size:18px;"> <span style="font-size:18px;">function addZore(x) {if (x < 10) {x = "0" + x;};return x;}//2002-12-18格式 function getCurentDate() { var date = new Date(); var mont

JavaScript时间处理之几个月前或几个月后的指定日期

在平常项目开发过程中,经常会遇到需要在JavaScript中处理时间的情况,无非两种(1,逻辑处理  2,格式转换处理).当然要说相关技术博,园子里闭着眼睛都能抓一把,但是我要做的是:既然有幸被我碰到了,就要尽可能的分析转化为自己最适合自己的东西,成为自己知识库的一部分:同时希望能帮助有需要的同学解决遇到的相关小问题. 时间逻辑处理   此类型常用需求为:推算几个月后(前)的今天的日期. 1 /** 2 *获取几个月前的输入日期 3 *{param:DateTime} date 输入日期(YYY

一个JavaScript日期格式化扩展函数

我们都知道在Java和PHP语言中,有专门用于格式化日期对象的类和函数,例如Java中的DateFormat等等,通过这些类和函数,我们可以方便的将一个日期对象按照格式的要求输出为字符串,例如对于同一个日期2006年12月25日,需要的显示格式可能如下: 2010年12月25日,2010-12-25,12-25-2010等等. 在Javascript之中,日期对象是Date,那么如何将一个日期对象按照定制的格式进行输出呢? Date对象有有四个内置方法,用于输出为字符串格式,分别为:广德县能源局

Javascript时间操作小结

来源:http://www.ido321.com/847.html 在项目需要一个计时器,效果如下: js代码 1: /*获取当前时间*/ 2: function getCurrentDate() 3: { 4: var timeStr = ''; 5: var curDate = new Date(); 6: var curMonth = curDate.getMonth()+1; //获取当前月份(0-11,0代表1月) 7: var curDay = curDate.getDate();

javascript 时间格式(很方便的原生函数)

原文:http://www.cnblogs.com/yjf512/p/3796229.html --------------------- <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script type=