对于yyyy-mm-dd hh:mm:ss 这种格式在ios系统不识别
时间格式化的时候,在浏览器端处理好好的,到了手机端,就变成NAN,或者null,这种情况,是ios系统不能转化这种类型的时间。
let date = new Date('2019-02-28 18:33:24'); // null
解决方案是,转成 yyyy/mm/dd hh:mm:ss 这种格式就可以了
replace(/-/g,"/")
js时间格式化函数
-
时间格式化
- @param {Object} dateObj 时间对象
- @param {String} fmt 格式化字符串
/
dateFormat(dateObj, fmt) {
let date;
if (this.isString(dateObj))
{
date = this.strToDate(dateObj)
} else if (this.isDate(dateObj))
{
date=dateObj
}
else{
return “”
}
var o = {
“M+”: date.getMonth() + 1, //月份
“d+”: date.getDate(), //日
“h+”: date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, //小时
“H+”: date.getHours(), //小时
“m+”: date.getMinutes(), //分
“s+”: date.getSeconds(), //秒
“q+”: Math.floor((date.getMonth() + 3) / 3), //季度
“S”: date.getMilliseconds() //毫秒
};
var week = {
“0”: “日”,
“1”: “一”,
“2”: “二”,
“3”: “三”,
“4”: “四”,
“5”: “五”,
“6”: “六”
};
if (/(y+)/.test(fmt)) {
fmt = fmt.replace(RegExp.$1, (date.getFullYear().toString() + “”).substr(4 - RegExp.$1.length));
}
if (/(E+)/.test(fmt)) {
fmt = fmt.replace(RegExp.$1, ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? “星期” : “周”) : “”) + week[date.getDay().toString() + “”]);
}
for (var k in o) {
if (new RegExp("(" + k + “)”).test(fmt)) {
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k].toString()) : ((“00” + o[k].toString()).substr(("" + o[k].toString()).length)));
}
}
return fmt;
}
/* - 字符串转换为时间
- @param {String} src 字符串
*/
strToDate(dateObj){
dateObj = dateObj.replace(/T/g, ’ ').replace(/.[\d]{3}Z/, ‘’).replace(/(-)/g, ‘/’)
if (dateObj.indexOf(".")>0)dateObj = dateObj.slice(0, dateObj.indexOf("."))
return new Date(dateObj)
}
dateFormat(“yyyy/MM/dd HH:mm:ss”) 结果 2019/02/25 10:09:11