美文网首页技术干货
ios safari 中时间 Invalid Date问题

ios safari 中时间 Invalid Date问题

作者: 一颗蛋_ | 来源:发表于2017-11-06 11:54 被阅读694次

    一般,我们用js实例化一个指定日期的时间对象可以这样使用:

    let date = new Date('2017-11-03 08:00:00')
    

    这段代码在ie、fierfox、chrome,以及移动安卓端都能正常运行,但是唯有在Safari和ios中显示为 Invalid Date ,why?
    原因是ios和safari不支持“YYYY-MM-DD”的时间格式,
    除此之外safari不支持的时间格式还有:

    • YYYY-M-DD ("2017-1-07")
    • YYYY-MM-DD hh:mm:ss ("2017-1-07 00:00:00")

    那么ie、fierfox、chrome,safari,ios,andriod共同支持的时间格式有那些?
    把‘-’换成‘/’就okay啦,或者将一位数的月份或日期前面加0变成两位数(较麻烦,不推荐使用)
    如下:

    • YYYY/MM/DD ("2017/11/7")
    • YYYY/MM/DD hh:mm:ss ("2017/11/7 00:00:00")
    • YYYY-MM-DD ("2017-01-07")
    • YYYY-MM-DDThh:mm:ss("2017-01-07T00:00:00")

    完美解决方案:

    function formatDate(date){
      return new Date(date.replace(/-/g, "/"))
    }
    let date=formatDate('2017-1-7')
    console.log(date);    //  Sat Jan 07 2017 00:00:00 GMT+0800 (CST)
    

    相关文章

      网友评论

        本文标题:ios safari 中时间 Invalid Date问题

        本文链接:https://www.haomeiwen.com/subject/fndqmxtx.html