javascript中日期时间处理函数

 代码如下 复制代码
/**
*把字符串转换为日期对象
*参数:日期字符串例如: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
*//
时间: 2024-09-29 18:50:58

javascript中日期时间处理函数的相关文章

javascript中日期时间比较代码

比如日期1为2009-8-1,日期2为2009-7-1 利用split函数来切分, 方法1  代码如下 复制代码 <script> var d1="2009-8-1"; var d2="2009-7-15"; d1Arr=d1.split('-'); d2Arr=d2.split('-'); v1=new Date(d1Arr[0],d1Arr[1],d1Arr[2]); v2=new Date(d2Arr[0],d2Arr[1],d2Arr[2]);

JavaScript中日期函数的相关操作知识_javascript技巧

时间对象是一个我们经常要用到的对象,无论是做时间输出.时间判断等操作时都与这个对象离不开.除开JavaScript中的时间对象外,在VbScript中也有许多的时间对象,而且非常好用.下面还是按照我们的流程来进行讲解JavaScript中日期函数. new Date() new Date(milliseconds) new Date(datestring) new Date(year, month) new Date(year, month, day) new Date(year, month,

JavaScript中 日期输入框焦点失去后,改变其他日期的时间

问题描述 JavaScript中 日期输入框焦点失去后,改变其他日期的时间 我选中第一个日期离开光标后,后面的日期怎样分别自动更改为第一个日期所在月的周二到周一的时间 解决方案 焦点失去有一个监听时间叫onblur(印象中差不多这样),可以让第一个时间注册这个监听事件,在监听时间的里面写js代码控制其他控件 解决方案二: 对应插件有自己的方法,看看api,然后找到设置值的方法使用就行了 解决方案三: 看日期插件的api,一般有对应的事件配置,如my97的onpicking,然后通过onpicki

javascript格式化日期时间方法汇总

  本文给大家汇总介绍了javascript格式化日期时间的五种常用方法,个人对第五种个性化输出时间比较有兴趣,基本上只要项目中能用到都是使用第五种,推荐给小伙伴们. 示例一: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&

JavaScript中的立即执行函数表达式介绍

 这篇文章主要介绍了JavaScript中的立即执行函数表达式介绍,本文着重讲解了什么是立即调用函数表达式,需要的朋友可以参考下     我们习惯看到这样的匿名函数 代码如下: (function(){ console.log("test"); })(); 之前一直叫的是自执行的匿名函数(self-executing anonymous function)   发现原来还有一种叫法是: 立即调用函数表达式 (IIFE,Immediately-Invoked Function Expre

JavaScript中5种调用函数的方法

 这篇文章主要介绍了JavaScript中5种调用函数的方法,本文详细的介绍了Javascript中各种函数调用的方法及其原理,对于理解JavaScript的函数有很大的帮助,需要的朋友可以参考下     这篇文章详细的介绍了Javascript中各种函数调用的方法及其原理,对于理解JavaScript的函数有很大的帮助! JavaScript,调用函数的5种方法 一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正理解Javascript函数是如何工作而导致的(顺便说一下

前端-Javascript中判断NaN,isNaN函数是否已经足够

问题描述 Javascript中判断NaN,isNaN函数是否已经足够 // Is the given value `NaN`? _.isNaN = function(obj) { return _.isNumber(obj) && isNaN(obj); }; 这个函数,为啥要先判断是否为Number,有这个必要吗 如果不判断,存在例外情况吗 解决方案 http://ourjs.com/detail/5383eb8f7610019548000012http://www.jb51.net/

javascript中call,apply,bind函数用法示例_javascript技巧

本文实例讲述了javascript中call,apply,bind函数用法.分享给大家供大家参考,具体如下: 一.call函数 a.call(b); 简单的理解:把a对象的方法应用到b对象上(a里如果有this,会指向b) call()的用法:用在函数上面 var Dog=function(){ this.name="汪星人"; this.shout=function(){ alert(this.name); } }; var Cat=function(){ this.name=&qu

请教lotus中的时间格式和JavaScript中的时间格式是否相同?

问题描述 请教lotus中的时间格式和JavaScript中的时间格式是否相同?我能在JavaScript中对两个时间值进行比较吗?如果可以的话,我该怎么转换数值?请各位大侠指点,谢谢啦! 解决方案 解决方案二:lotus的时间格式很多,可以根据你的程序要求进行修改~~