`
yushine
  • 浏览: 200471 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

js中date对象扩展的相关函数

 
阅读更多

该文章收集了对js中date对象扩展的相关函数,包括:
把字符串转换为日期对象
格式化日期
计算两个日期之间的差值
判断一个年份是否为闰年

/**
*把字符串转换为日期对象
*参数:日期字符串例如:2011-04-19或者19/04/2011
*返回:日期对象Date
*注:IE下不支持直接实例化日期对象,如new Date("2011-04-06")
**/
Date.prototype.converDate=function(date){
	var flag=true;
	var dateArray=date.splite("-");
	if(dateArray.length!=3){
		dateArray=date.splite("/");
		if(dataArray.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;
};
/*
demo
<script type="text/javascript">
document.writeln(new Date().convertDate("7/12/2011"));
</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() + "<BR>");
    document.writeln(new Date().convertDate("2011-04-08").isLeapYear() + "<BR>");
    </script>
    // 结果:
    // true
    // false
    */
 
/*
函数:计算两个日期之间的差值
参数: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>
      */
 
/*
 
函数:格式化日期
参数:formatStr-格式化字符串
d:将日显示为不带前导零的数字,如1
dd:将日显示为带前导零的数字,如01
ddd:将日显示为缩写形式,如Sun
dddd:将日显示为全名,如Sunday
<SPAN class="goog_qs-tidbit goog_qs-tidbit-0">M:将月份显示为不带前导零的数字,如一月显示为1
MM:将月份显示为带前导零的</SPAN>数字,如01
MMM:将月份显示为缩写形式,如Jan
MMMM:将月份显示为完整月份名,如January
yy:以两位数字格式显示年份
yyyy:以四位数字格式显示年份
h:使用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 
*//
分享到:
评论

相关推荐

    Javascript 日期对象Date扩展

    Date对象扩展,包括常用中文日期格式解析、加减操作、日期差、周操作和季操作。具体扩展的方法如下: parseCHS--静态方法。解析常用的中文日期并返回日期对象。 add--日期加减操作。[注:此函数在上传时还存在...

    关于js的Date对象的有用扩展

    在“关于js的Date对象的有用扩展”中,我们可以看到一些额外的功能或方法,可能是对原生Date对象的扩展,以满足更复杂的日期处理需求。 在`date.js`文件中,很可能包含了一些自定义函数或原型扩展,这些扩展可能...

    Date对象的补充函数,包括类似Python中的strftime()

    在这个场景中,datetime.js-master库可能就是这样一个工具,它为JavaScript的Date对象添加了更多格式化日期和时间的方法。 在Python的datetime模块中,strftime()方法允许开发者将日期和时间对象转换为格式化的字符...

    JS中获取Date对象实现实时钟表小demo

    在JavaScript中,Date对象是处理日期和时间的核心工具。它提供了丰富的功能,允许开发者获取、设置和操作日期和时间。当我们想要实现实时钟表,也就是一个不断更新当前时间的时钟,我们可以利用JavaScript的定时器...

    NextDate函数小程序

    6. **扩展性**:考虑如何修改或扩展函数,使其支持获取下一个工作日、下一个特定日期等功能。 通过这个NextDate函数小程序,你可以深入理解日期处理的基本原理,同时提升编程技巧和问题解决能力。在实际项目中,...

    javascript转换日期字符串为Date日期对象的方法.docx

    ### JavaScript 转换日期字符串为 Date 日期对象的方法 在 JavaScript 开发中,处理日期是非常常见的需求之一。很多时候,我们需要将用户输入或其他来源得到的日期字符串转换为 `Date` 对象,以便进行进一步的计算...

    w3cshool之JavaScript对象_Date

    在JavaScript编程语言中,`Date`对象是一种非常实用且功能强大的工具,主要用于处理与日期和时间相关的数据。通过`Date`对象,开发者可以轻松地获取系统当前的日期和时间,并对这些数据进行格式化处理或执行复杂的...

    再践javascript对象、原型、属性、构造函数、扩展、json.docx

    ### JavaScript对象、原型、属性、构造函数、扩展、JSON #### JavaScript对象类型 JavaScript是一种广泛使用的脚本语言,尤其在Web开发中占据了重要的地位。它支持多种对象类型,包括内部对象、基于类的对象以及...

    de1.7 轻量级的javascript扩展函数库

    de.js是一个轻量级的javascript扩展函数库,通过扩展页面元素的方法和属性、和扩展javascript内置类型的方法来帮助web前端开发人员实现更便捷和高效的编程。以下是主要特点: 支持类似jquery的选择器,同时支持类似...

    JavaScript版的DateAdd、DateDiff、IsDate函数

    JavaScript是Web开发中不可或缺的一部分,尤其在处理时间与日期相关的操作时。在.NET或VBScript中,我们有内置的DateAdd、DateDiff和IsDate函数,它们分别用于添加时间间隔、计算两个日期之间的差值以及验证一个值...

    javascript的date转化器

    这个“javascript的date转化器”可能是一个自定义的库或函数集合,旨在简化和扩展JavaScript内置Date对象的功能,以满足更复杂的日期操作需求。在JavaScript中,Date对象允许我们创建、读取、操作和格式化日期。 1....

    js获取时间函数及扩展函数的方法

    总的来说,JavaScript的Date对象和相关的扩展函数提供了强大的日期和时间处理能力,能够帮助开发者在前端开发中进行复杂的日期操作,无论是简单的显示格式化还是复杂的日期计算。通过理解并熟练运用这些方法,开发者...

    基于prototype扩展的JavaScript常用函数库

    在JavaScript中,Array和Date对象是两个常用的内置对象,分别用于处理数组和日期相关操作。本知识点将详细解释如何利用原型扩展技术来增强这两个对象的能力,使其具备更加丰富的功能。 首先,我们来看如何扩展Array...

    js自定义对象讲解

    在JavaScript中,自定义对象可以通过对象字面量或构造函数来创建,以扩展语言的功能。它们与JS的标准对象相对,后者如Date、Array等是由语言内置的。 1.2.2 原型(prototype) 原型是JavaScript中一种特殊的概念,...

    JavaScript对象模型

    在JavaScript中,函数同样是一种对象,具有特殊的内部属性`[[Class]]`,其值为`"Function"`,表明它是函数类型。函数可以作为普通的对象使用,也可以作为构造函数来创建新的对象实例。在实现上,函数拥有特定的内部...

    ASP.NET AJAX深入浅出系列课程(8):JavaScript中的原生对象以及Microsoft AJAX Library中的相关扩展(下)_PDF.zip

    在这个深入浅出的系列课程中,我们将聚焦于JavaScript中的原生对象以及Microsoft AJAX Library中的相关扩展,特别是下篇的内容。 JavaScript是Web开发中不可或缺的脚本语言,它提供了丰富的原生对象来支持各种功能...

    ASP.NET AJAX深入浅出系列课程(7):Microsoft AJAX Library对于JavaScript原生对象的扩展(上)

    在AJAX库中,你可以找到如parseDate和formatDate这样的函数,它们分别用于解析和格式化日期字符串,解决了JavaScript原生Date对象在这方面的不足。此外,还有新增的时间比较和操作方法,如add和subtract,方便开发者...

    js date

    DP_DateExtensions.js是一个为JavaScript的`Date`对象扩展了更多功能的库,它提供了方便的日期比较、日期间隔计算以及各种格式化选项。例如,你可以方便地检查日期是否在另一日期之前或之后,或者计算两个日期之间的...

    JavaScript对象模型-执行模型

    函数在JS中扮演着非常重要的角色,它可以被视为面向对象编程中的“类”,用来创建对象实例。 #### 二、内置数据类型 内置数据类型是指由JS语言本身提供的预定义类型,这些类型提供了对基本数据类型的封装和扩展...

    js版DateDiff, DateAdd, DatePart等日期数据扩展函数,非常实用

    总之,这些扩展函数极大地丰富了JavaScript中的日期处理能力,使得开发者能够更高效地处理各种日期相关的逻辑,从而提高应用程序的性能和用户体验。通过理解和应用这些函数,你可以在自己的项目中实现更加灵活和复杂...

Global site tag (gtag.js) - Google Analytics