js 根据指定阳历日期转换为农历日期

<html>
	<head>
		<meta charset="UTF-8">
		<title>日期</title>
	</head>
	<body>
		<div id="pDate"></div>
	</body>
</html>
<script type="text/javascript">
	var sWeek = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六");
	var dNow = new Date();
	var CalendarData = new Array(100);
	var madd = new Array(12);
	var tgString = "甲乙丙丁戊己庚辛壬癸";
	var dzString = "子丑寅卯辰巳午未申酉戌亥";
	var numString = "一二三四五六七八九十";
	var monString = "正二三四五六七八九十冬腊";
	var sx = "鼠牛虎兔龙蛇马羊猴鸡狗猪";
	var cYear, cMonth, cDay, TheDate;
	CalendarData = new Array(0xA4B, 0x5164B, 0x6A5, 0x6D4, 0x415B5, 0x2B6, 0x957, 0x2092F, 0x497, 0x60C96, 0xD4A, 0xEA5, 0x50DA9, 0x5AD, 0x2B6, 0x3126E, 0x92E, 0x7192D, 0xC95, 0xD4A, 0x61B4A, 0xB55, 0x56A, 0x4155B, 0x25D, 0x92D, 0x2192B, 0xA95, 0x71695, 0x6CA, 0xB55, 0x50AB5, 0x4DA, 0xA5B, 0x30A57, 0x52B, 0x8152A, 0xE95, 0x6AA, 0x615AA, 0xAB5, 0x4B6, 0x414AE, 0xA57, 0x526, 0x31D26, 0xD95, 0x70B55, 0x56A, 0x96D, 0x5095D, 0x4AD, 0xA4D, 0x41A4D, 0xD25, 0x81AA5, 0xB54, 0xB6A, 0x612DA, 0x95B, 0x49B, 0x41497, 0xA4B, 0xA164B, 0x6A5, 0x6D4, 0x615B4, 0xAB6, 0x957, 0x5092F, 0x497, 0x64B, 0x30D4A, 0xEA5, 0x80D65, 0x5AC, 0xAB6, 0x5126D, 0x92E, 0xC96, 0x41A95, 0xD4A, 0xDA5, 0x20B55, 0x56A, 0x7155B, 0x25D, 0x92D, 0x5192B, 0xA95, 0xB4A, 0x416AA, 0xAD5, 0x90AB5, 0x4BA, 0xA5B, 0x60A57, 0x52B, 0xA93, 0x40E95);
	madd[0] = 0;
	madd[1] = 31;
	madd[2] = 59;
	madd[3] = 90;
	madd[4] = 120;
	madd[5] = 151;
	madd[6] = 181;
	madd[7] = 212;
	madd[8] = 243;
	madd[9] = 273;
	madd[10] = 304;
	madd[11] = 334;

	function GetBit(m, n) {
		return(m >> n) & 1;
	}

	function e2c() {
		TheDate = (arguments.length != 3) ? new Date() : new Date(arguments[0], arguments[1], arguments[2]);
		var total, m, n, k;
		var isEnd = false;
		var tmp = TheDate.getFullYear();
		total = (tmp - 1921) * 365 + Math.floor((tmp - 1921) / 4) + madd[TheDate.getMonth()] + TheDate.getDate() - 38;
		if(TheDate.getYear() % 4 == 0 && TheDate.getMonth() > 1) {
			total++;
		}
		for(m = 0;; m++) {
			k = (CalendarData[m] < 0xfff) ? 11 : 12;
			for(n = k; n >= 0; n--) {
				if(total <= 29 + GetBit(CalendarData[m], n)) {
					isEnd = true;
					break;
				}
				total = total - 29 - GetBit(CalendarData[m], n);
			}
			if(isEnd) break;
		}
		cYear = 1921 + m;
		cMonth = k - n + 1;
		cDay = total;
		if(k == 12) {
			if(cMonth == Math.floor(CalendarData[m] / 0x10000) + 1) {
				cMonth = 1 - cMonth;
			}
			if(cMonth > Math.floor(CalendarData[m] / 0x10000) + 1) {
				cMonth--;
			}
		}
	}

	/*戊戌狗年 腊月廿*/
	function GetcDateString() {
		var tmp = "";
		tmp += tgString.charAt((cYear - 4) % 10);
		tmp += dzString.charAt((cYear - 4) % 12);
		tmp += sx.charAt((cYear - 4) % 12);
		tmp += "年 ";
		if(cMonth < 1) {
			tmp += "(闰)";
			tmp += monString.charAt(-cMonth - 1);
		} else {
			tmp += monString.charAt(cMonth - 1);
		}
		tmp += "月";
		tmp += (cDay < 11) ? "初" : ((cDay < 20) ? "十" : ((cDay < 30) ? "廿" : "三十"));
		if(cDay % 10 != 0 || cDay == 10) {
			tmp += numString.charAt((cDay - 1) % 10);
		}
		return tmp;
	}

	function GetLunarDay(solarYear, solarMonth, solarDay) {
		if(solarYear < 1921 || solarYear > 2020) {
			return "";
		} else {
			solarMonth = (parseInt(solarMonth) > 0) ? (solarMonth - 1) : 11;
			e2c(solarYear, solarMonth, solarDay);
			return GetcDateString();
		}
	}
	

	function getFullYear(d) { // 修正firefox下year错误
		var yr = d.getYear();
		if(yr < 1000) yr += 1900;
		return yr;
	}

/*写入页面*/
	function showDate() {
		
		var D = new Date();
		var yy = D.getFullYear();
		var mm = D.getMonth() + 1;
		var dd = D.getDate();
		var ww = D.getDay();
		var ss = parseInt(D.getTime() / 1000);
		var h = D.getHours();
		var m = D.getMinutes();
		var s = D.getSeconds();
		
		var sValue = getFullYear(dNow) + "年" + (dNow.getMonth() + 1) + "月" + dNow.getDate() + "日" + " " + sWeek[dNow.getDay()] + " ";
		sValue += GetLunarDay(yy, mm, dd);
		sValue += shapetime(h,m,s);
		document.getElementById("pDate").innerHTML = sValue;
		setTimeout("showDate()", 500);
	};

/*格式化时间*/
	function shapetime(h, m, s) {
		if(s <= 9) s = "0" + s;
		if(m <= 9) m = "0" + m;
		if(h <= 9) h = "0" + h;
		return h + ":" + m + ":" + s
	}

	window.onload = showDate;
</script>

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
实现日历具体日期的公历农历转换可以参考以下步骤: 1. 创建公历转农历的函数,该函数的输入为公历年月日,输出为农历年月日。 2. 在 JavaScript 中,获取用户选择的日期,并将其转换为公历年月日。 3. 调用公历转农历的函数,将公历年月日转换农历年月日。 4. 将公历和农历日期渲染到 HTML 页面中。 下面是一个简单的实现: HTML: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Calendar</title> </head> <body> <table id="calendar"></table> <div> <span>公历日期:</span><input type="date" id="date"> <button onclick="convert()">确定</button> </div> <div> <span>农历日期:</span><span id="lunar"></span> </div> <script src="calendar.js"></script> </body> </html> ``` JavaScript: ```js // 公历转农历函数 function solarToLunar(year, month, day) { // TODO: 实现公历转农历的算法 } // 获取当前日期 var today = new Date(); // 获取当前月份 var month = today.getMonth(); // 获取当前年份 var year = today.getFullYear(); // 获取本月天数 var daysInMonth = new Date(year, month + 1, 0).getDate(); // 获取本月第一天是星期几 var firstDayOfMonth = new Date(year, month, 1).getDay(); // 生成日历数据 var calendarData = []; var day = 1; for (var i = 0; i < 6; i++) { calendarData[i] = []; for (var j = 0; j < 7; j++) { if (i === 0 && j < firstDayOfMonth) { calendarData[i][j] = ""; } else if (day > daysInMonth) { calendarData[i][j] = ""; } else { calendarData[i][j] = day; day++; } } } // 渲染日历数据 var calendar = document.getElementById("calendar"); for (var i = 0; i < 6; i++) { var row = calendar.insertRow(i); for (var j = 0; j < 7; j++) { var cell = row.insertCell(j); cell.innerHTML = calendarData[i][j]; } } // 公历转农历并渲染到页面中 function convert() { var date = new Date(document.getElementById("date").value); var year = date.getFullYear(); var month = date.getMonth() + 1; var day = date.getDate(); var lunar = solarToLunar(year, month, day); document.getElementById("lunar").innerHTML = lunar.year + "年" + lunar.month + "月" + lunar.day + "日"; } ``` 需要注意的是,公历转农历的算法比较复杂,可以参考一些第三方的库或者 API 来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值