JS实现时间格式化

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就可以了

你可能感兴趣的:(javascript)