JS时间格式化函数
根据传入的格式字符串, 把事件格式化成指定格式的时间字符串
/**
* 时间格式化函数, 按照指定格式化字符串格式化传入时间
*
* @param {Date} time 需要格式化的时间
* @param {String} fmStr 定义时间的格式
* yyyy: 代表四位数年份
* yy: 代表两位数年份
* mm: 代表月份(小于10时补0)
* dd: 代表日期(小于10时补0)
* hh: 代表小时(小于10时补0)
* hh: 代表小时(小于10时补0)
* MM: 代表分钟(小于10时补0)
* ss: 代表秒数(小于10时补0)
* SSS: 代表毫秒数
* w: 代表周几(数字)
* W: 代表周几(中文)
* ww: 代表周几(英文)
* @returns {String} 返回格式化的时间
*/
function timeFormat(time, fmStr) {
const weekCN = '一二三四五六日';
const weekEN = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'];
let year = time.getFullYear();
let month = time.getMonth() + 1;
let day = time.getDate();
let hours = time.getHours();
let minutes = time.getMinutes();
let seconds = time.getSeconds();
let milliSeconds = time.getMilliseconds();
let week = time.getDay();
month = month >= 10 ? month : ('0' + month);
day = day >= 10 ? day : ('0' + day);
hours = hours >= 10 ? hours : ('0' + hours);
minutes = minutes >= 10 ? minutes : ('0' + minutes);
seconds = seconds >= 10 ? seconds : ('0' + seconds);
if (fmStr.indexOf('yyyy') !== -1) {
fmStr = fmStr.replace('yyyy', year);
} else {
fmStr = fmStr.replace('yy', (year + '').slice(2));
}
fmStr = fmStr.replace('mm', month);
fmStr = fmStr.replace('dd', day);
fmStr = fmStr.replace('hh', hours);
fmStr = fmStr.replace('MM', minutes);
fmStr = fmStr.replace('ss', seconds);
fmStr = fmStr.replace('SSS', milliSeconds);
fmStr = fmStr.replace('W', weekCN[week - 1]);
fmStr = fmStr.replace('ww', weekEN[week - 1]);
fmStr = fmStr.replace('w', week);
return fmStr;
}
如果你觉得用函数去处理比较麻烦, 也可以吧这个函数添加到Date对象的原型上, 这样只需要用Date对象直接调用就可以了
Date.prototype.format = function(fmStr){
timeFormat(this, fmStr);
}
var time = new Date();
var fm = time.format('yyyy-mm-dd');
上面的代码为了方便没有改写代码, 而是在原型上format函数中调用timeFormat函数
实际上可以直接把timeFormat函数直接赋给原型上的format的
只需要把timeFormat中的参数修改一下, 不需要再传入time参数, 直接使用time作为time就可以了