在JavaScript开发中,经常需要对Date类型的对象进行各种验证或格式化,但是js并没有提供那么多的那么细的函数,所以只好自己去用 prototype 扩充了,下面是我自己实现的Date类型常用操作方法,你可以将它另存为date.js,然后在程序中调用即可。

/**
* 日期时间脚本库方法列表:
* (1)Date.isValiDate:日期合法性验证
* (2)Date.isValiTime:时间合法性验证
* (3)Date.isValiDateTime:日期和时间合法性验证
* (4)Date.prototype.isLeapYear:判断是否闰年
* (5)Date.prototype.format:日期格式化
* (6)Date.stringToDate:字符串转成日期类型
* (7)Date.daysBetween:计算两个日期的天数差
* (8)Date.prototype.dateAdd:日期计算,支持正负数
* (9)Date.prototype.dateDiff:比较日期差:比较两个时期相同的字段,返回相差值
* (10)Date.prototype.toArray:把日期分割成数组:按数组序号分别为:年月日时分秒
* (11)Date.prototype.datePart:取得日期数据信息
*/ /**
* 日期合法性验证:判断dataStr是否符合formatStr指定的日期格式
* 示例:
* (1)alert(Date.isValiDate('2008-02-29','yyyy-MM-dd'));//true
* (2)alert(Date.isValiDate('aaaa-58-29','yyyy-MM-dd'));//false
* dateStr:必选,日期字符串
* formatStr:可选,格式字符串,可选格式有:(1)yyyy-MM-dd(默认格式)或YYYY-MM-DD (2)yyyy/MM/dd或YYYY/MM/DD (3)MM-dd-yyyy或MM-DD-YYYY (4)MM/dd/yyyy或MM/DD/YYYY
*/
Date.isValiDate = function(dateStr, formatStr)
{
if(!dateStr){
return false;
}
if(!formatStr){
formatStr = "yyyy-MM-dd";//默认格式:yyyy-MM-dd
}
if(dateStr.length!=formatStr.length){
return false;
}else{
if(formatStr=="yyyy-MM-dd"||formatStr=="YYYY-MM-DD"){
var r1=/^(((((([02468][048])|([13579][26]))(00))|(d{2}(([02468][48])|([13579][26]))))-((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-([0-2][0-9]))))|(d{2}(([02468][1235679])|([13579][01345789]))-((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-(([0-1][0-9])|(2[0-8]))))))$/;
return r1.test(dateStr);
}else if(formatStr=="yyyy/MM/dd"||formatStr=="YYYY/MM/DD"){
var r2=/^(((((([02468][048])|([13579][26]))(00))|(d{2}(([02468][48])|([13579][26]))))/((((0[13578])|(1[02]))/(([0-2][0-9])|(3[01])))|(((0[469])|(11))/(([0-2][0-9])|(30)))|(02/([0-2][0-9]))))|(d{2}(([02468][1235679])|([13579][01345789]))/((((0[13578])|(1[02]))/(([0-2][0-9])|(3[01])))|(((0[469])|(11))/(([0-2][0-9])|(30)))|(02/(([0-1][0-9])|(2[0-8]))))))$/;
return r2.test(dateStr);
}else if(formatStr=="MM-dd-yyyy"||formatStr=="MM-DD-YYYY"){
var r3=/^((((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-([0-2][0-9])))-(((([02468][048])|([13579][26]))(00))|(d{2}(([02468][48])|([13579][26])))))|(((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-(([0-1][0-9])|(2[0-8])))))-d{2}(([02468][1235679])|([13579][01345789])))$/;
return r3.test(dateStr);
}else if(formatStr=="MM/dd/yyyy"||formatStr=="MM/DD/YYYY"){
var r4=/^((((((0[13578])|(1[02]))/(([0-2][0-9])|(3[01])))|(((0[469])|(11))/(([0-2][0-9])|(30)))|(02/([0-2][0-9])))/(((([02468][048])|([13579][26]))(00))|(d{2}(([02468][48])|([13579][26])))))|(((((0[13578])|(1[02]))/(([0-2][0-9])|(3[01])))|(((0[469])|(11))/(([0-2][0-9])|(30)))|(02/(([0-1][0-9])|(2[0-8])))))/d{2}(([02468][1235679])|([13579][01345789])))$/;
return r4.test(dateStr);
}else{
alert("日期格式不正确!");
return false;
}
}
return false;
} /**
* 时间合法性验证:判断timeStr是否符合formatStr指定的时间格式
* 示例:
* (1)alert(Date.isValiTime('23:59:59','hh:mm:ss'));//true
* (2)alert(Date.isValiTime('24-68-89','hh:mm:ss'));//false
* timeStr:必选,日期字符串
* formatStr:可选,格式字符串,可选格式有:(1)hh:mm:ss(默认格式) (2)hh-mm-ss (3)hh/mm/ss
*/
Date.isValiTime = function(timeStr, formatStr)
{
if(!timeStr){
return false;
}
if(!formatStr){
formatStr = "hh:mm:ss";//默认格式:hh:mm:ss
}
if(timeStr.length!=formatStr.length){
return false;
}else{
if(formatStr=="hh:mm:ss"){
var r1=/^(([0-1][0-9])|(2[0-3])):([0-5][0-9]):([0-5][0-9])$/;
return r1.test(timeStr);
}else if(formatStr=="hh-mm-ss"){
var r2=/^(([0-1][0-9])|(2[0-3]))-([0-5][0-9])-([0-5][0-9])$/;
return r2.test(timeStr);
}else if(formatStr=="hh/mm/ss"){
var r3=/^(([0-1][0-9])|(2[0-3]))/([0-5][0-9])/([0-5][0-9])$/;
return r3.test(timeStr);
}else{
alert("时间格式不正确!");
return false;
}
}
return false;
} /**
* 日期和时间合法性验证
* 格式:yyyy-MM-dd hh:mm:ss
*/
Date.isValiDateTime = function(dateTimeStr)
{
var dateTimeReg=/^(((((([02468][048])|([13579][26]))(00))|(d{2}(([02468][48])|([13579][26]))))-((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-([0-2][0-9]))))|(d{2}(([02468][1235679])|([13579][01345789]))-((((0[13578])|(1[02]))-(([0-2][0-9])|(3[01])))|(((0[469])|(11))-(([0-2][0-9])|(30)))|(02-(([0-1][0-9])|(2[0-8]))))))(s{1}(([0-1][0-9])|(2[0-3])):([0-5][0-9]):([0-5][0-9]))?$/
return dateTimeReg.test(dateTimeStr);
} /**
* 判断闰年 :一般规律为:四年一闰,百年不闰,四百年再闰。
*/
Date.prototype.isLeapYear = function()
{
return (this.getYear()%4==0&&((this.getYear()0!=0)||(this.getYear()%400==0)));
} /**
* 日期格式化:
* formatStr:可选,格式字符串,默认格式:yyyy-MM-dd hh:mm:ss
* 约定如下格式:
* (1)YYYY/yyyy/YY/yy 表示年份
* (2)MM/M 月份
* (3)W/w 星期
* (4)dd/DD/d/D 日期
* (5)hh/HH/h/H 时间
* (6)mm/m 分钟
* (7)ss/SS/s/S 秒
* (8)iii 毫秒
*/
Date.prototype.format = function(formatStr)
{
var str = formatStr;
if(!formatStr){
str = "yyyy-MM-dd hh:mm:ss";//默认格式
}
var Week = ['日','一','二','三','四','五','六']; str=str.replace(/yyyy|YYYY/,this.getFullYear());
str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100)); str=str.replace(/MM/,this.getMonth()>=9?(parseInt(this.getMonth())+1).toString():'0' + (parseInt(this.getMonth())+1));
str=str.replace(/M/g,(parseInt(this.getMonth())+1)); str=str.replace(/w|W/g,Week[this.getDay()]); str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate());
str=str.replace(/d|D/g,this.getDate()); str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours());
str=str.replace(/h|H/g,this.getHours());
str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes());
str=str.replace(/m/g,this.getMinutes()); str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds());
str=str.replace(/s|S/g,this.getSeconds()); str=str.replace(/iii/g,this.getMilliseconds()<10?'00'+this.getMilliseconds():(this.getMilliseconds()<100?'0'+this.getMilliseconds():this.getMilliseconds())); return str;
} /**
* 字符串转成日期类型:
* dateStr:必选,日期字符串,如果无法解析成日期类型,返回null
* 格式:
* (1)yyyy/MM/dd:IE和FF通用
* (2)MM/dd/yyyy:IE和FF通用
* (3)MM-dd-yyyy:仅IE
* (4)yyyy-MM-dd:非IE,且时钟被解析在8点整
*/
Date.stringToDate = function(dateStr)
{
if(!dateStr){
alert("字符串无法解析为日期");
return null;
}else{
if(Date.isValiDate(dateStr,"yyyy/MM/dd")||Date.isValiDate(dateStr,"MM/dd/yyyy")){
return new Date(Date.parse(dateStr));
}else{
if((!-[1,])){//IE
if(Date.isValiDate(dateStr,"MM-dd-yyyy")){
return new Date(Date.parse(dateStr));
}else{
alert("字符串无法解析为日期");
return null;
}
}else{//非IE
if(Date.isValiDate(dateStr,"yyyy-MM-dd")){
return new Date(Date.parse(dateStr));
}else{
alert("字符串无法解析为日期");
return null;
}
}
}
}
return null;
} /**
* 计算两个日期的天数差:
* dateOne:必选,必须是Data类型的实例
* dateTwo:必选,必须是Data类型的实例
*/
Date.daysBetween = function(dateOne,dateTwo)
{
if((dateOne instanceof Date)==false||(dateTwo instanceof Date)==false){
return 0;
}else{
return Math.abs(Math.floor((dateOne.getTime()-dateTwo.getTime())/1000/60/60/24));
}
} /**
* 日期计算:支持负数,即可加可减,返回计算后的日期
* num:必选,必须是数字,且正数是时期加,负数是日期减
* field:可选,标识是在哪个字段上进行相加或相减,字段见如下的约定。无此参数时,默认为d
* 约定如下格式:
* (1)Y/y 年 * (2)M 月
* (3)W/w 周
* (4)D/d 日
* (5)H/h 时
* (6)m 分
* (7)S/s 秒
* (8)Q/q 季
*/
Date.prototype.dateAdd = function(num, field)
{
if((!num)||isNaN(num)||parseInt(num)==0){
return this;
}
if(!field){
field = "d";
}
switch(field){
case 'Y':
case 'y':return new Date((this.getFullYear()+num), this.getMonth(), this.getDate(), this.getHours(), this.getMinutes(), this.getSeconds());break;
case 'Q':
case 'q':return new Date(this.getFullYear(), (this.getMonth()+num*3), this.getDate(), this.getHours(), this.getMinutes(), this.getSeconds());break;
case 'M':return new Date(this.getFullYear(), this.getMonth()+num, this.getDate(), this.getHours(), this.getMinutes(), this.getSeconds());break;
case 'W':
case 'w':return new Date(Date.parse(this) + ((86400000 * 7) * num));break;
case 'D':
case 'd':return new Date(Date.parse(this) + (86400000 * num));break;
case 'H':
case 'h':return new Date(Date.parse(this) + (3600000 * num));break;
case 'm':return new Date(Date.parse(this) + (60000 * num));break;
case 'S':
case 's':return new Date(Date.parse(this) + (1000 * num));break;
default: return this;
}
return this;
} /**
* 比较日期差:比较两个时期相同的字段,返回相差值
* dtEnd:必选,必须是Data类型的实例
* field:可选,标识是在哪个字段上进行比较,字段见如下的约定。无此参数时,默认为d
* 约定如下格式:
* (1)Y/y 年
* (2)M 月
* (3)W/w 周
* (4)D/d 日
* (5)H/h 时
* (6)m 分
* (7)S/s 秒
*/
Date.prototype.dateDiff = function(dtEnd, field)
{
var dtStart = this;
if((dtEnd instanceof Date)==false){
return 0;
}else{
if(!field){
field = "d";
}
switch(field){
case 'Y':
case 'y':return dtEnd.getFullYear() - dtStart.getFullYear();break;
case 'M':return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1);break;
case 'W':
case 'w':return parseInt((dtEnd - dtStart) / (86400000 * 7));break;
case 'D':
case 'd':return parseInt((dtEnd - dtStart) / 86400000);break;
case 'H':
case 'h':return parseInt((dtEnd - dtStart) / 3600000);break;
case 'm':return parseInt((dtEnd - dtStart) / 60000);break;
case 'S':
case 's':return parseInt((dtEnd - dtStart) / 1000);break;
default: return 0;
}
return 0;
}
} /**
* 把日期分割成数组:按数组序号分别为:年月日时分秒
*/
Date.prototype.toArray = function()
{
var myArray = new Array();
myArray[0] = this.getFullYear();
myArray[1] = this.getMonth();
myArray[2] = this.getDate();
myArray[3] = this.getHours();
myArray[4] = this.getMinutes();
myArray[5] = this.getSeconds();
return myArray;
} /**
* 取得日期数据信息:
* field:可选,标识是在哪个字段上进行比较,字段见如下的约定。无此参数时,默认为d
* (1)Y/y 年
* (2)M 月
* (3)W/w 周
* (4)D/d 日
* (5)H/h 时
* (6)m 分
* (7)S/s 秒
*/
Date.prototype.datePart = function(field)
{
if(!field){
field = "d";
}
var Week = ['日','一','二','三','四','五','六'];
switch (field){
case 'Y' :
case 'y' :return this.getFullYear();break;
case 'M' :return (this.getMonth()+1);break;
case 'W' :
case 'w' :return Week[this.getDay()];break;
case 'D' :
case 'd' :return this.getDate();break;
case 'H' :
case 'h' :return this.getHours();break;
case 'm' :return this.getMinutes();break;
case 's' :return this.getSeconds();break;
default:return this.getDate();
}
return this.getDate();
}

JavaScript Date的原型方法扩展的更多相关文章

  1. JavaScript Date 时间对象方法

    Date(日期/时间对象) Date 操作日期和时间的对象 Date.getDate( ) 返回一个月中的某一天 Date.getDay( ) 返回一周中的某一天 Date.getFullYear( ...

  2. javascript中的原型和闭包

    定义 //闭包测试 function bbTest() { var local = "这里是本地变量"; //闭包会扩大局部变量的作用域,具备变量一致会存活到函数之外,在函数之外可 ...

  3. javascript数组原型方法

    1.javascript数组原型方法. <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  4. JavaScript Date 日期属性和方法

    JavaScript 日期(Date) Date对象用于处理日期和时间.使用对象new Date()创建日期.实例化日期有四种方式: var d1 = new Date(); var d2 = new ...

  5. JavaScript -- 时光流逝(五):js中的 Date 对象的方法

    JavaScript -- 知识点回顾篇(五):js中的 Date 对象的方法 Date 对象: 用于处理日期和时间. 1. Date对象的方法 <script type="text/ ...

  6. JavaScript中的类方法、对象方法、原型方法

    类方法:也叫函数方法,在JavaScript中函数也是一个对象,所以可以为函数添加属性以及方法: 对象方法:包括构造函数中的方法以及其原型上面的方法: 原型方法:一般用于对象实例共享,在原型上面添加该 ...

  7. javascript: 类、方法、原型

    // 类.方法.原型 //================================================================================== /* 类 ...

  8. javascript方法扩展

    String.prototype.startWith = function(str){ return str.indexOf(str) == 0; }; var str = "abc&quo ...

  9. javascript中的类方法、构造方法、原型方法的对比

    如果你已经接触js很久了,那么应该可以看看我总结的是否正确,如果你刚开始学习,那么通过我的总结,你可以更快的区别他们,记得我刚接触js时,这一块反正是模糊了很久! 1,长相的区别: function ...

随机推荐

  1. MySQL☞数值处理函数

    1.round():四舍五入函数 round(数值,参数):如果参数的值为正数,表示保留几位小数,如果参数的值为0,则只保留正数部分们如果参数的值为负数,表示对小数点前第几位进行四舍五入. Eg:(1 ...

  2. 破解IDEA注册码,设置 license server一直有效不过期

    破解的详细过程: 1.从下面地址下载一个jar包,名称是  JetbrainsCrack-2.10-release-enc.jar 下载地址是http://idea.lanyus.com/,进去之后点 ...

  3. LeeCode第一次刷题(两数相加)

    题目描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组 ...

  4. 【Linux】Face Recognition的封装

    使用虹软的人脸识别 写了一个linux下的Face Recognition的封装,当作是练习. C++的封装,结合opencv,使用方便.https://github.com/zacario-li/F ...

  5. 2018科大讯飞AI营销算法大赛全面来袭,等你来战!

    AI技术已成为推动营销迭代的重要驱动力.AI营销高速发展的同时,积累了海量的广告数据和用户数据.如何有效应用这些数据,是大数据技术落地营销领域的关键,也是检测智能营销平台竞争力的标准. 讯飞AI营销云 ...

  6. GRU-CTC中文语音识别

    目录 基于keras的中文语音识别 音频文件特征提取 文本数据处理 数据格式处理 构建模型 模型训练及解码 aishell数据转化 该项目github地址 基于keras的中文语音识别 该项目实现了G ...

  7. openstack架构

    终于正式进入 OpenStack 部分了. 今天开始,CloudMan 将带着大家一步一步揭开 OpenStack 的神秘面纱. OpenStack 已经走过了 6 个年头. 每半年会发布一个版本,版 ...

  8. selenium识别登录验证码---基于python实现

    本文主要是通过PIL+pytesseract+Tesseract-OCR实现验证码的识别 其中PIL为Python Imaging Library,已经是Python平台事实上的图像处理标准库了.PI ...

  9. android 出现Make sure the Cursor is initialized correctly before accessing data from it

    Make sure the Cursor is initialized correctly before accessing data from it 详细错误是:java.lang.IllegalS ...

  10. TCP系列27—窗口管理&流控—1、概述

    在前面的内容中我们依次介绍了TCP的连接建立和终止过程和TCP的各种重传方式.接着我们在这部分首先关注交互式应用TCP连接相关内容如延迟ACK.Nagle算法.Cork算法等,接着我们引入流控机制(f ...