firefox浏览器下JS的new Date()的值为Invalid Date、NaN-NaN的问题

解决日期字符串转换问题
本文介绍了在不同浏览器中使用newDate方法将日期字符串转换为Date格式的问题及解决方案,并提供了多种适用于所有浏览器的日期字符串格式。

 

当我们需要将一串日期字符串转换为具体的Date格式的时候,往往需要用到new Date("xxxx")方法。

当时在IE浏览器下,会遇到这种问题:

new Date('2016-01-01 00:00:00')    //却返回这个值Invalid Date,转换失败

但是这个方法却在谷歌浏览器上可以返回正确的结果。

 

解决方式:最终发现是字符串的格式不被某些浏览器失败,而导致的。

new Date('2016/01/01 00:00:00')  //这下就转换正确了Wed Jan 1 00:00:00 UTC+0800 2014

在具体使用的时候,可以通过一些字符串转换的方式,将日期字符串格式转换正确之后,再使用new Date()。

var date="2016-12-12 10:10:10";
date=date.replace(new RegExp(/-/gm) ,"/");   //将所有的'-'转为'/'即可
Date d=new Date(date);

 

所以,不同的浏览器还是存在差异的,以下列出了所有浏览器都支持的方式。

1 var d = new Date(2011, 01, 07); // yyyy, mm-1, dd  
2 var d = new Date(2011, 01, 07, 11, 05, 00); // yyyy, mm-1, dd, hh, mm, ss  
3 var d = new Date("02/07/2011"); // "mm/dd/yyyy"  
4 var d = new Date("02/07/2011 11:05:00"); // "mm/dd/yyyy hh:mm:ss"  
5 var d = new Date(1297076700000); // milliseconds  
6 var d = new Date("Mon Feb 07 2011 11:05:00 GMT"); // ""Day Mon dd yyyy hh:mm:ss GMT/UTC

 

getDateDiffNew2(pTime:string) {
    let result;
    let minute:number = 60;
    let hour:number = minute * 60;
    let day:number = hour * 24;
    let month:number = day * 30;
    let now = new Date().getTime()/1000;
    pTime=pTime.replace(new RegExp(/-/gm) ,"/");   //将所有的'-'转为'/'即可
    let old = new Date(pTime).getTime()/1000;
    let nn = parseInt(String(now));
    let oo = parseInt(String(old));
    let diffValue:number = Number(now) - Number(old);
    let monthC:number = diffValue / month;
    let weekC:number = diffValue / (7 * day);
    let dayC:number = diffValue / day;
    let hourC:number = diffValue / hour;
    let minC:number = diffValue / minute;

    if (monthC >= 1) {
      if(monthC > 12)
      {
        result = pTime.substring(0,10);
      }
      else if(monthC == 1)
      {
        result = pTime.substring(5,10);
      }
      else
      {
        result = pTime.substring(5,10);
      } 
    }
    else if (weekC >= 1) {
      result = pTime.substring(5,10);
    }
    else if (dayC >= 1) {
      result = pTime.substring(5,10);
    }
    else if (hourC >= 1) {
      result = Math.round(hourC) + "小时前";
    }
    else if (minC >= 1) {
      result = Math.round(minC) + "分钟前";
    } 
    else
    {
      result = "刚刚";
    } 
    //var b:String = new String(diffValue);
    //var b:string = <string> String(nn) ;
    //var o:string = <string> String(old) ;
    //return b + ':' + o;
    return result;
  }

 

转载于:https://my.oschina.net/yizhichao/blog/1540619

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值