做项目过程中,找到的一些js常用时间处理函数

简介: 1、把JS里面的Date规范输出为“YYYY-MM-DD HH:mm:SS”的字符串把下面的代码复制到你的JS里,Date对象就可以直接调用toCommonCase(): Date.

1、把JS里面的Date规范输出为“YYYY-MM-DD HH:mm:SS”的字符串
  1. 把下面的代码复制到你的JS里,Date对象就可以直接调用toCommonCase():

  2. Date.prototype.toCommonCase=function(){
  3. var xYear=this.getYear();
  4. xYear=xYear+1900;

  5. var xMonth=this.getMonth()+1;
  6. if(xMonth10){
  7. xMonth="0"+xMonth;
  8. }

  9. var xDay=this.getDate();
  10. if(xDay10){
  11. xDay="0"+xDay;
  12. }

  13. var xHours=this.getHours();
  14. if(xHours10){
  15. xHours="0"+xHours;
  16. }

  17. var xMinutes=this.getMinutes();
  18. if(xMinutes10){
  19. xMinutes="0"+xMinutes;
  20. }

  21. var xSeconds=this.getSeconds();
  22. if(xSeconds10){
  23. xSeconds="0"+xSeconds;
  24. }
  25. return xYear+"-"+xMonth+"-"+xDay+" "+xHours+":"+xMinutes+":"+xSeconds;
  26. }

2、日期格式校验
  1. //判断输入的内容是否为日期格式
  2. function checkDateFormate(Field) {
  3.     var inputDateValue = Field.value;
  4.     var desc = Field.description;
  5.     if(inputDateValue == null || inputDateValue == '') {
  6.        return false;
  7.     }

  8.     //获取输入字符串的长度
  9.     var inputValueLength = inputDateValue.length;
  10.     //如果满足下面判断的所有条件才算合法的日期,否则不合法
  11.     if(checkNumeric(inputDateValue) && checkLegth(inputValueLength) && checkSpecialChar(inputDateValue) ) {
  12.        return true;
  13.     }else {
  14. errorMessage("请输入合法的" + desc +"\n类型为日期,格式为YYYY-MM-DD 或者YYYYMMDD");
  15.        Field.focus();
  16.        return false;
  17.     }
  18. }

  19. //日期只能是8~10位
  20. function checkLegth(length) {
  21.     if(length 8 || length > 10) {
  22.        return false;
  23.     }
  24.     return true;
  25. }

  26. //如果输入的内容中包含‘-’,则按照‘-’分割来去年月日,否则直接按照位数取
  27. function checkSpecialChar(inputDateValue) {
  28.     var index = inputDateValue.indexOf('-');
  29.     var year = 0;
  30.     var month = 0;
  31.     var day = 0;
  32.     if(index > -1) {
  33.        var lastIndex = inputDateValue.lastIndexOf('-');
  34.        //只能是YYYY-M-DD或者YYYY-MM-DD的形式
  35.        if(lastIndex - index 1 || lastIndex - index > 3) {
  36.            return false;
  37.        }
  38.        var arrDate = inputDateValue.split('-');
  39.            year = arrDate[0];
  40.            month = arrDate[1];
  41.            day = arrDate[2];
  42.        } else {
  43.            year = inputDateValue.substring(0,4);
  44.            month = inputDateValue.substring(4,6);
  45.            day = inputDateValue.substring(6,8);
  46.        }
  47.        if(Number(month) > 12 || Number(day) > 31 ||Number(month)1
  48.                            || Number(day)1 || year.length != 4) {
  49.            return false;
  50.     } else if(day > getLastDayOfMonth(Number(year),Number(month))) {
  51.            return false;
  52.     }
  53.     return true;
  54. }

  55. //判断输入的内容将‘-’替换成为数字1后,是否全部为数字
  56. function checkNumeric(inputDateValue) {
  57.     var replacedValue = inputDateValue.replace(/-/g,'1');
  58.     return isNumeric(replacedValue);
  59. }

  60. //判断是否为数字
  61. function isNumeric(strValue)
  62. {
  63.   var result = regExpTest(strValue,/\d*[.]?\d*/g);
  64.   return result;
  65. }

  66. function regExpTest(source,re)
  67. {
  68.   var result = false

  69.   if(source==null || source=="")
  70.     return false;
  71.   if(source==re.exec(source))
  72.     result = true;
  73.   return result;
  74. }


  75. //获得一个月中的最后一天
  76. function getLastDayOfMonth(year,month){
  77.     var days=0;
  78.     switch(month){
  79.     case 1: case 3: case 5: case 7: case 8: case 10: case 12: days=31;break;
  80.     case 4: case 6: case 9: case 11: days=30;break;
  81.     case 2: if(isLeapYear(year)) days=29;else days=28;break;
  82.     }
  83.     return days;
  84. }

  85. //判断是否为闰年
  86. function isLeapYear(year){
  87.     if((year %4==0 && year %100!=0) || (year %400==0)) return true;
  88.     else return false;
  89. }

3、字符串转日期
  1. function strToDate(str)
  2. {
  3.   var arys= new Array();
  4.   arys=str.split('-');
  5.   //1月份是用0来表示的,所以2002年10月12日,应表示为2002-9-12
  6. var newDate=new Date(arys[0],arys[1]-1,arys[2]);
  7.   return newDate;
  8. }

4、日期转字符串
  1. function strToDate(str)
  2. {
  3.   var val=Date.parse(str);
  4.   var newDate=new Date(val);
  5.   return newDate;
  6. }

5、自己写的jQuery时间判断,使用了上面的某些函数
  1. $(":button").click(function(){
  2.         if($(":text:eq(0)").val() =='' ||$(":text:eq(1)").val() =='' ){
  3.             alert("请先填写查询时间!");
  4.             return false;
  5.         }checkSpecialChar
  6.         if(!checkSpecialChar($(":text:eq(0)").val()) || !checkSpecialChar($(":text:eq(0)").val()) ){
  7.             alert("时间格式错误!");
  8.             return false;
  9.         }
  10.         var arys1= new Array();
  11.         var arys2= new Array();
  12.         arys1=$(":text:eq(0)").val().split('-');
  13.         arys2=$(":text:eq(1)").val().split('-');
  14.         
  15.   //1月份是用0来表示的,所以2002年10月12日,应表示为2002-9-12
  16.         var newDate1 = new Date(arys1[0],arys1[1]-1,arys1[2]);
  17.         var newDate2 = new Date(arys2[0],arys2[1]-1,arys2[2]);
  18.         
  19.         if(newDate1 > newDate2 ){
  20.             alert("起始日期不能大于终止日期!");
  21.             return false;
  22.         }
  23.         $("form[name='form1']").submit();
  24.     });


相关文章
|
2月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
46 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
2月前
|
JavaScript 前端开发 安全
JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择
本文深入探讨了JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择。JavaScript以其灵活性和广泛的生态支持著称,而TypeScript通过引入静态类型系统,提高了代码的可靠性和可维护性,特别适合大型项目。文章还讨论了结合使用两种语言的优势,以及如何根据项目需求和技术背景做出最佳选择。
66 4
|
2月前
|
CDN
如何在项目中使用Moment.js库?
如何在项目中使用Moment.js库?
|
2月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
3月前
|
JavaScript 测试技术 API
跟随通义灵码一步步升级vue2(js)项目到vue3版本
Vue 3 相较于 Vue 2 在性能、特性和开发体验上都有显著提升。本文介绍了如何利用通义灵码逐步将 Vue 2 项目升级到 Vue 3,包括备份项目、了解新特性、选择升级方式、升级依赖、迁移组件和全局 API、调整测试代码等步骤,并提供了注意事项和常见问题的解决方案。
109 4
|
3月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
3月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
3月前
|
JavaScript 前端开发 测试技术
JavaScript与TypeScript:为何TypeScript成为大型项目的首选
JavaScript与TypeScript:为何TypeScript成为大型项目的首选
37 1
|
3月前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
3月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
55 4