項目上與時間相關的地方特別多,與時間格式相關都使用了moment.js輕量級日期處理庫,在開發中出現了幾次瀏覽器兼容性問題,所以總結一下new Date()和moment.js在各大瀏覽器中兼容性問題,方便記憶或查閱。
后台傳回來的時間格式一般是字符串“2017-9-10 21:02:02”;
然后將字符串轉化為標准時間:
var str = "2017-9-10 21:12:20"; var time = new Date(str); console.log(time);
然后查看了一下,在chrome,firefox較新版本表現正常,在firefox老版本和ie中輸出invalid date。
了解其原因,不是瀏覽器都支持“-”,“/”才是被各大瀏覽器廣泛支持的。即把“-”替換為“/”即可解決問題。
var time = new Date(str.replace("-", "/").replace("-", "/"));
或者
var time = new Date(str.replace(/-/g,"/"));
還有一種解決方法就是直接用從字符串中獲取年月日時分秒的數字來生成日期:
var time = new Date("2017","9","10","21","33","33",);
這個兼容性問題是最常見,接下來講講不常見的。
//未完待續