JS的一些时间获取和计算公用方法封装

本文分享了作者整理的JavaScript中关于日期获取和时间格式化的实用方法,通过代码示例展示如何进行时间操作和格式转换。
摘要由CSDN通过智能技术生成

又是一个记录博客,不想废话的一天。。。。
自己之前写的时间计算和日期格式化的源码整理,直接看代码吧~~

/**
 * 判断年份是否为润年
 * @param {Number} year
 * @return {Boolean}
 */
isLeapYear: function (year) {
   
	return (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0);
},

/**
 * 获取某一年份的某一月份的天数
 * @param {Number} year
 * @param {Number} month
 * @return {String}
 */
getMonthDays: function (year, month) {
   
	return [31, null, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month] || (isLeapYear(year) ? 29 : 28);
},

/**
 * 获取某年的某天是第几周
 * @param {Number} y
 * @param {Number} m
 * @param {Number} d
 * @returns {Number}
 */
getWeekNumber: function (y, m, d, curDate) {
   
	var now = curDate;
	if (now == '') {
   
		now = new Date(y, m - 1, d);
	}
	var year = now.getFullYear(),
		month = now.getMonth(),
		days = now.getDate();
	//那一天是那一年中的第多少天
	for (var i = 0; i < month; i++) {
   
		days += getMonthDays(year, i);
	}
	//那一年第一天是星期几
	var yearFirstDay = new Date(year, 0, 1).getDay() || 7;
	var week = null;
	if (yearFirstDay == 1) {
   
		week = Math.ceil(days / yearFirstDay);
	} else {
   
		days -= (7 - yearFirstDay + 1);
		week = Math.ceil(days / 7) + 1;
	}
	return week;
},
/**
 * 日期转换
 * @return
 */
formatDate: {
   
	format: function (date, pattern) {
   
		pattern = pattern || DEFAULT_PATTERN;
		return pattern.replace(SIGN_REGEXP, function ($0) {
   
			switch ($0.charAt(0)) {
   
				case 'y': return padding(date.getFullYear(), $0.length);
				case 'M': return padding(date.getMonth() + 1, $0.length);
				case 'd': return padding(date.getDate(), $0.length);
				case 'w': return date.getDay() + 1;
				case 'h': return padding(date.getHours(), $0.length);
				case 'm': return padding(date.getMinutes(), $0.length);
				case 's': return padding(date.getSeconds(), $0.length);
			}
		});
	},
	parse: function (dateString, pattern) {
   
		var matchs1 = pattern.match(SIGN_REGEXP);
		var matchs2 = dateString.match(/(\d)+/g
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值