日期格式化方法
直接可以在vue中使用new Date().Format ('yyyy-MM-dd hh:mm:ss')
的全局方便方法
Date.prototype.Format = function(fmt) {
//author: meizz
var o = {
"M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日
"h+": this.getHours(), //小时
"m+": this.getMinutes(), //分
"s+": this.getSeconds(), //秒
"q+": Math.floor((this.getMonth() + 3) / 3), //季度
S: this.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt))
fmt = fmt.replace(
RegExp.$1,
(this.getFullYear() + "").substr(4 - RegExp.$1.length)
);
for (var k in o)
if (new RegExp("(" + k + ")").test(fmt))
fmt = fmt.replace(
RegExp.$1,
RegExp.$1.length == 1
? o[k]
: ("00" + o[k]).substr(("" + o[k]).length)
);
return fmt;
}
获取每个月有多少天
new Date(2019, 12, 0).getDate(); // 31
// 根据这个我们可以得到一个方法
function getMonthLength(month) {
const date = new Date(month);
const year = date.getFullYear();
// 月份是从 0 开始计算的
const _month = date.getMonth() + 1;
return new Date(year, _month, 0).getDate();
}
否为一个时间格式
业务中遇到一个校验一下传入时间格式是否为一个时间格式,下面的方法可以完美校验
const isDate = str => {
return typeof str !== 'number' && str !== null && new Date(str) !== 'Invalid Date';
};