站三界导航
首页 uniapp代码uni-app 实战:1、万年历模板样式

uni-app 实战:1、万年历模板样式

  • uniapp代码
  • 来源:站三界导航
  • 174阅读
  • 2023-05-10

踩坑注意事项:

1、pages.json 文件信息改变后要重新编译下,否则不展示效果

2、uni-app 组件支持的生命周期,与 vue 标准组件的生命周期相同。这里没有页面级的 onLoad 等生命周期

总算调试好了,模拟器上 没有问题啦。

效果图

接下来上源码,


日历组件部分

<template name="pre_wnl">
	<view class="pre_wnl_body" v-bind:style="{ width: t_width + 'px' }">
		<view class="header">
			<picker mode="date" :value="date" :start="startDate" :end="endDate" @change="bindDateChange">
				<view class="uni-input">{{now_year}}年{{now_month}}月<i></i></view>
			</picker>
		</view>
		<!-- 当前日期详情 -->
		<view class="grid clearfix">
			<view class="day-left clearfix">
				<h1>{{now_day}}</h1>
				<view class="top-contrl">
					<view><em>{{now_week}}</em></view>
					<view><i>{{now_lunar}}</i></view>
				</view>
			</view>
			<view class="day-right clearfix">
				<view class="yun" @click="load_data">
					<span class="js_jin">今</span>
				</view>
			</view>
		</view>

		<!-- 日历标题 -->
		<view class="week_title">
			<view class="week_title_day">
				<text class="week_title_day_text red">日</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text">一</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text">二</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text">三</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text">四</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text">五</text>
			</view>
			<view class="week_title_day">
				<text class="week_title_day_text red">六</text>
			</view>

		</view>
		<!-- 日志天数 -->
		<swiper class="swiper" :duration="duration" :current="activeIndex" @change="fun_indexChange">
			<swiper-item v-for="(month,swiperindex) in swiperList" :key="swiperindex">
				<view class="month_days uni-column">
					<view class="month_week uni-row" v-for="(week,index) in month.monthdays" :key="index">
						<view class="month_day" v-for="(item,id) in week" :key="id">
							<view class="month_day_item" hover-class="hover_click" :hover-start-time="5" :class="{isNow: item.isNow,isWeeklast: item.isWeeklast,isToday:item.isToday}"
							 @click="fun_sel_day(item)">
								<view class="month_day_1">{{item.day}}</view>
								<view class="month_day_2" :class="{isTerm:item.isTerm}">{{item.Iday}}</view>
							</view>
						</view>
					</view>
				</view>
			</swiper-item>
		</swiper>
	</view>
</template>

<script>
	/*
	名称:万年历
	日期:2020-02-26
	作者:hj
	目标:
	*/
	// 引入外部 CSS
	import '../static/css/common.css'
	// 引入外部js
	import {
		getfulldata,
		getalldays_byweek,
		getNextmonth
	} from '../utils/action_date.js'

	export default {
		name: "pre_wnl",
		data() {
			const currentDate = this.getDate({
				format: true
			})
			return {
				t_width: '',
				now_year: '',
				now_month: '',
				now_day: '',
				now_week: '',
				now_lunar: '',
				date: currentDate,
				startDate: '1950-01-01',
				endDate: '2099-01-01',
				swiperList: [],
				activeIndex: 1,
				duration: 300

			};
		},
		mounted: function() {
			console.log('加载完成,开始计算当前日期');

			var _self = this;
			this.$nextTick(function() {
				// 如何有子组件加载完毕判断就用这里
				_self.load_data();
			})
		},
		methods: {
			load_data: function() {
				// 设置自适应宽度
				this.t_width = uni.getSystemInfoSync().windowWidth;
				// 设置默认日期
				var dd = new Date();
				// console.log('年=' + dd.getFullYear() + ' 月=' + dd.getMonth() + ' 日=' + dd.getDay() + ' 星期=' + dd.getDate());

				let year = dd.getFullYear();
				let month = dd.getMonth() + 1;
				let day = dd.getDate();
				month = month > 9 ? month : '0' + month;
				day = day > 9 ? day : '0' + day;

				this.now_year = year;
				this.now_month = month;
				this.now_day = day;
				this.fun_init_week();
				this.fun_init_lunar();
				// 设置选择日期范围
				// console.log('格式化日期 ' + this.getDate());
				// 设置显示日期
				this.swiperList=[];
				this.activeIndex=1;
				this.fun_init_days();

			},
			bindDateChange: function(e) {
				this.date = e.target.value;
				this.now_year = this.date.substring(0, 4);
				this.now_month = this.date.substring(5, 7);
				this.now_day = this.date.substring(8, 10);
				this.fun_init_week();
				this.fun_init_lunar();
				this.fun_init_days();
			},
			fun_init_data: function(y,m,d) {
				this.now_year = y;
				this.now_month = m;
				this.now_day = d;
				this.fun_init_week();
				this.fun_init_lunar();
			},
			fun_init_week: function() {
				var weeks = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
				// console.log('ID=' + new Date(this.now_year, this.now_month, this.now_day).getDay());
				this.now_week = weeks[new Date(this.now_year, this.now_month, this.now_day).getDay() - 1];
			},
			fun_init_lunar: function() {
				// console.log(getfulldata(this.now_year, this.now_month, this.now_day));
				var cd = getfulldata(this.now_year, this.now_month, this.now_day);
				this.now_lunar = cd.IMonthCn + cd.IDayCn;
			},
			fun_init_days: function() {
				// 直接获取当前日期对应月的所有天的信息
				// this.alldays = getalldays_byweek(this.now_year, this.now_month, this.now_day);
				// console.log('=========全部天数=========');
				// console.log(this.alldays);
				var b = {},
					a = {};
				b = getNextmonth(this.now_year , this.now_month , this.now_day, -1);
				a = getNextmonth(this.now_year , this.now_month , this.now_day, 1);
				this.swiperList=[];
				var monthdays={};
				monthdays=getalldays_byweek(b.y, b.m, b.d);
				this.swiperList.push({
					'monthdays':monthdays,
					'y':b.y,
					'm':b.m,
					'd':b.d
				});
				monthdays=getalldays_byweek(this.now_year, this.now_month, this.now_day);
				this.swiperList.push({
					'monthdays':monthdays,
					'y':this.now_year,
					'm':this.now_month,
					'd':this.now_day
				});
				monthdays=getalldays_byweek(a.y, a.m, a.d);
				this.swiperList.push({
					'monthdays':monthdays,
					'y':a.y,
					'm':a.m,
					'd':a.d
				});
			},
			fun_sel_day: function(item) {
				// console.log(item);
				// console.log(item.year + ' == ' + item.month + ' == ' + item.day + ' == ' + item.Iday);
				// console.log(this.now_month+'  '+item.month);
				this.now_year = item.year;
				this.now_month = item.month;
				this.now_day = item.day;
				this.now_lunar = item.Iday;
				this.now_week = item.week;
			},
			fun_indexChange: function(e) {
				var index = e.detail.current;
				console.log('当前激活ID = ' + e.detail.current + '  当前列表长度= ' + this.swiperList.length);

				this.activeIndex = e.detail.current;

				if (index == (this.swiperList.length - 1)) {
					// console.log("add data");
					var b = {},i=0;
					i=this.swiperList.length - 1;
					b = getNextmonth(this.swiperList[i].y , this.swiperList[i].m , this.swiperList[i].d, 1);					
					var monthdays={};
					monthdays=getalldays_byweek(b.y, b.m, b.d);
					this.swiperList.push({
						'monthdays':monthdays,
						'y':b.y,
						'm':b.m,
						'd':b.d
					});
				}

				if (index == 0) {
					// console.log("add data");
					/* 关闭切换效果 */
					this.duration = 0;

					/* 关闭切换效果 */
					this.duration = 0;
					this.$nextTick(() => {
						var a = [];
						var b = {};
						b = getNextmonth(this.swiperList[0].y , this.swiperList[0].m , this.swiperList[0].d, -1);					
						var monthdays={};
						monthdays=getalldays_byweek(b.y, b.m, b.d);
						a.push({
							'monthdays':monthdays,
							'y':b.y,
							'm':b.m,
							'd':b.d
						});
						this.swiperList = a.concat(this.swiperList);

						/* 切换到轮播第0个 */
						this.activeIndex = 1;

						this.$nextTick(() => {
							/* 恢复切换效果 */
							this.duration = 300;
						})
					});
				}

				this.fun_init_data(this.swiperList[this.activeIndex].y,this.swiperList[this.activeIndex].m,this.swiperList[this.activeIndex].d)
				console.log('activeIndex = ' + e.detail.current + ' 更新后长度= ' + this.swiperList.length + ' \n');
			},
			fun_stransChange: function(e) {
				// console.log(e.detail);
			},
			getDate(type) {
				const date = new Date();
				let year = date.getFullYear();
				let month = date.getMonth() + 1;
				let day = date.getDate();

				if (type === 'start') {
					year = year - 60;
				} else if (type === 'end') {
					year = year + 2;
				}
				month = month > 9 ? month : '0' + month;
				day = day > 9 ? day : '0' + day;
				return `${year}-${month}-${day}`;
			}
		}
	}
</script>

<style scoped>
	.pre_wnl_body {
		/* #ifndef APP-NVUE */
		display: flex;
		/* #endif */
		flex-direction: column;
	}

	.header {
		background: #DA5751;
		height: 44px;
		border-bottom: 1px solid #f07575;
		width: 94%;
		padding: 0 3%;
		display: flex;
		display: -webkit-flex;
		display: -ms-flexbox;
		flex-wrap: wrap;
		align-items: center;
		text-align: center;
		color: #fff;
	}

	.header>picker {
		font-size: 16px;
		font-style: normal;
		/* 上下左右居中 margin:0 auto; */
		margin: 0 auto;
	}

	.header i {
		display: inline-block;
		width: 10px;
		height: 5px;
		background: url(../static/image/calendar_bottom.png) no-repeat;
		background-size: cover;
		margin-left: 3px;
	}

	.grid {
		background: #DA5751;
		width: 94%;
		margin: 0 auto;
		height: 100%;
		padding: 0 3%;
		display: flex;
		display: -webkit-flex;
		display: -ms-flexbox;
		align-items: center;
		color: white;
	}

	.day-left {
		display: flex;
		display: -webkit-flex;
		display: -ms-flexbox;
		flex: 0;
		flex-grow: 0;
		flex-shrink: 0;
		flex-basis: 56%;
		-webkit-flex: 0;
		-webkit-flex-grow: 0;
		-webkit-flex-shrink: 0;
		-webkit-flex-basis: 56%;
	}

	.day-right {
		display: flex;
		display: -webkit-flex;
		display: -ms-flexbox;
		flex: 0;
		flex-grow: 0;
		flex-shrink: 0;
		flex-basis: 44%;
		-webkit-flex: 0;
		-webkit-flex-grow: 0;
		-webkit-flex-shrink: 0;
		-webkit-flex-basis: 44%;
		align-items: center;
		justify-content: flex-end;
		-webkit-justify-content: flex-end;
		-ms-justify-content: flex-end;
	}

	.day-left h1 {
		font-size: 56px;
		padding-right: 8px;
	}

	.day-left .top-contrl p {
		display: flex;
		display: flex;
		display: -webkit-flex;
		align-items: center;
		flex-wrap: wrap;
		-webkit-align-items: center;
		-webkit-flex-wrap: wrap;
		margin-top: .1rem;
	}

	.top-contrl em {
		display: flex;
		font-size: 12px;
		margin-top: 10px;
	}

	.top-contrl i {
		font-size: 20px;
	}

	.day-right .yun {
		height: 100%;
		display: flex;
		display: -webkit-flex;
		display: -ms-flexbox;
		align-items: center;
		-webkit-align-items: center;
	}

	.day-right .yun span {
		display: inline-block;
		width: 30px;
		height: 30px;
		line-height: 30px;
		text-align: center;
		border: 2px solid #fff;
		border-radius: 50%;
		margin-left: 15px;
		/*align-self:center;*/
		font-size: 18px;
		/* font-weight: bold; */
	}

	/* 标题部分 */
	.week_title {
		position: relative;
		/* #ifndef APP-NVUE */
		display: flex;
		/* #endif */
		flex-direction: row;
		margin-top: 20px;
	}

	.week_title_day {
		flex: 1;
		/* #ifndef APP-NVUE */
		display: flex;
		/* #endif */
		flex-direction: column;
		justify-content: center;
		align-items: center;
		height: 45px;
		border-bottom-color: #F5F5F5;
		border-bottom-style: solid;
		border-bottom-width: 1px;
	}

	.week_title_day_text {
		font-size: 14px;
	}

	.red {
		color: #ff0000;
	}

	.month_days {
		display: flex;
	}

	.month_week {
		display: flex;
		padding-top: 4px;
	}

	.uni-column {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		flex-direction: column;
	}

	.uni-row {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-webkit-flex-direction: row;
		flex-direction: row;
	}

	.month_day {
		flex: 0;
		flex-grow: 0;
		flex-shrink: 0;
		flex-basis: 13%;
		justify-content: center;
		position: relative;
		padding: 0px 2px 0px 2px;
		text-align: center;
	}

	.month_day_item {
		border: 2px solid #fff;
		padding: 5px 0px 5px 0px;
		color: #e5dee2;
	}

	.month_day_item:hover {
		border: 2px solid #f20 !important;
	}

	.month_day_1 {
		font-size: 24px;

	}

	.month_day_2 {
		font-size: 12px;
	}

	.isNow {
		color: #000000;
	}

	.isWeeklast {
		color: #ff0000;
	}

	.isTerm {
		color: rgb(0, 183, 236);
		;
	}

	.isToday {
		color: #ffffff;
		background-color: #ec5252;
		border: 2px solid #f20 !important;
		border-radius: 8px;
	}

	.hover_click {
		border: 2px solid #f20 !important;
	}

	.swiper {
		height: 360px;
	}
</style>
action_date.js 文件

"use strict";

import CALENDAR from './calendar.js'

// 获取日期附加信息
export function getfulldata(y, m, d) {
	return CALENDAR.solar2lunar(y, m, d);
}

// 获取按周计算的所有天数
export function getalldays_byweek(y, m, d) {
	// 思路
	// 构建一个数组 天 包含 上月剩余天 本月天 下月剩余天(如果本月最后一天是周六,则不计算)
	let
		fullArr = [],
		dateArr = [],
		before_dateArr = [],
		after_dateArr = [];
	// 获取本月天数详情
	dateArr = getmonthdays(y, m, d);
	// 获取上月天数详情 
	let before_days = 0;
	var weeks = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
	for (var i = 0; i < weeks.length; i++) {
		if (dateArr[0].week == weeks[i]) {
			// console.log(dateArr[0].week + ' = ' + weeks[i]);
			before_days = i;
			break;
		}
	}
	// console.log('上月天数=' + before_days);
	if (before_days > 0) {
		before_dateArr = getbeforemonthdays(y, m, before_days);
		// console.log(before_dateArr);
	}
	// 获取下月剩余天数
	let after_days = 0;
	for (var i = 0; i < weeks.length; i++) {
		if (dateArr[dateArr.length - 1].week == weeks[i]) {
			// console.log(dateArr[0].week + ' = ' + weeks[i]);
			after_days = 7 - i;
			break;
		}
	}
	// console.log('下月天数=' + after_days);
	if (after_days > 0) {
		after_dateArr = getaftermonthdays(y, m, after_days);
		// console.log(after_dateArr);
	}

	if (before_dateArr.length > 0 && after_dateArr.length > 0) {
		fullArr = before_dateArr.concat(dateArr, after_dateArr);
	} else if (before_dateArr.length > 0 && after_dateArr.length == 0) {
		fullArr = before_dateArr.concat(dateArr);
	} else if (before_dateArr.length == 0 && after_dateArr.length > 0) {
		fullArr = dateArr.concat(after_dateArr);
	} else {
		fullArr = dateArr;
	}
	// console.log(fullArr);
	// 重组 按7天
	let weeks_arr = [];
	let week_arr = [];
	let num = 0;
	for (var i = 0; i < fullArr.length; i++) {
		if (num == 7) {
			num = 0;
		}

		if (num < 7) {
			week_arr.push(fullArr[i]);
		}

		if (num == 6) {
			weeks_arr.push(week_arr);
			week_arr = [];

		}

		num++;

	}

	return weeks_arr;
}

// 按月获取天数详情
export function getmonthdays(y, m, d) {
	let dateArr = [];
	let num = 0;
	let days = new Date(y, m, 0);
	num = days.getDate();
	// console.log('显示' + m + '月份所有天数=' + num);

	// 今天
	let today = y + '-' + m + '-' + d;

	for (let i = 1; i <= num; i++) {
		// 判断是否今天
		let nowDate = y + '-' + m + '-' + (i < 10 ? '0' + i : i);

		// 是否今天
		let isToday = today === nowDate;

		// 阴历信息
		let lunar = CALENDAR.solar2lunar(y, m, i);

		let data = {
			fullDate: nowDate,
			year: y,
			month: m,
			day: i < 10 ? '0' + i : i,
			Iday: lunar.Term ? lunar.Term : lunar.IDayCn,
			isTerm: lunar.Term ? true : false,
			isNow: true,
			isToday: isToday,
			isWeeklast: (lunar.ncWeek == '星期六' || lunar.ncWeek == '星期日') ? true : false,
			week: lunar.ncWeek
		}
		dateArr.push(data);
	}
	return dateArr;
}

// 获取上月剩余天数详情
export function getbeforemonthdays(y, m, lastdays) {
	let dateArr = [];
	let num = 0;
	let mm = Number(m);

	if ((mm - 1) == 0) {
		mm = 12;
	} else {
		mm = mm - 1;
	}

	let days = new Date(y, mm, 0);

	num = days.getDate();
	// console.log('显示当前月份所有天数=' + num);

	lastdays = num - lastdays + 1;

	for (let i = lastdays; i <= num; i++) {
		let nowDate = y + '-' + (mm < 10 ? '0' + mm : mm) + '-' + (i < 10 ? '0' + i : i);

		// 是否今天
		let isToday = false;

		// 阴历信息
		let lunar = CALENDAR.solar2lunar(y, mm, i);

		let data = {
			fullDate: nowDate,
			year: y,
			month: mm < 10 ? '0' + mm : mm,
			day: i < 10 ? '0' + i : i,
			Iday: lunar.Term ? lunar.Term : lunar.IDayCn,
			isTerm: false,
			isNow: false,
			isToday: isToday,
			isWeeklast: false,
			week: lunar.ncWeek
		}
		dateArr.push(data);
	}
	return dateArr;
}

// 获取下一个月天数详情
export function getaftermonthdays(y, m, lastdays) {
	let dateArr = [];
	let num = 0;
	let mm = Number(m);
	if ((mm + 1) == 13) {
		mm = 1;
	} else {
		mm = mm + 1;
	}

	for (let i = 1; i <= lastdays; i++) {
		let nowDate = y + '-' + (mm < 10 ? '0' + mm : mm) + '-' + (i < 10 ? '0' + i : i);

		// 是否今天
		let isToday = false;

		// 阴历信息
		let lunar = CALENDAR.solar2lunar(y, mm, i);

		let data = {
			fullDate: nowDate,
			year: y,
			month: mm < 10 ? '0' + mm : mm,
			day: i < 10 ? '0' + i : i,
			Iday: lunar.Term ? lunar.Term : lunar.IDayCn,
			isTerm: false,
			isNow: false,
			isToday: isToday,
			isWeeklast: false,
			week: lunar.ncWeek
		}
		dateArr.push(data);
	}
	return dateArr;
}

// 获取指定日期的前一天后一天
// date 标准格式日期2020-02-27  day间隔天数 1或-1
export function getNextday(date, day) {
	var dd = new Date(date);
	dd.setDate(dd.getDate() + day);
	var y = dd.getFullYear();
	var m = dd.getMonth() + 1 < 10 ? "0" + (dd.getMonth() + 1) : dd.getMonth() + 1;
	var d = dd.getDate() < 10 ? "0" + dd.getDate() : dd.getDate();

	var j = {};
	j = {
		'y': y + '',
		'm': m + '',
		'd': d + ''
	};
	return j;
}

// 获取指定日期的前一月或后一月
// date 标准格式日期2020-02-27  num间隔天数 1或-1
export function getNextmonth(year, month, day, num) {
	var y = 0,
		m = 0,
		d = 0;
	y = Number(year);
	m = Number(month);
	d = Number(day);

	if ((m + num) > 12) {
		m = m + num - 12;
		y++;
	} else if ((m + num) <= 0) {
		m = m + num + 12;
		y--;
	} else {
		m = m + num;
	}

	var j = {};
	j = {
		'y': y + '',
		'm': m < 10 ? '0' + m : '' + m,
		'd': d < 10 ? '0' + d : '' + d
	};
	return j;
}
calendar.js 文件,来自网络

/**
* @1900-2100区间内的公历、农历互转
* @charset UTF-8
* @github  https://github.com/jjonline/calendar.js
* @Author  Jea杨(JJonline@JJonline.Cn)
* @Time    2014-7-21
* @Time    2016-8-13 Fixed 2033hex、Attribution Annals
* @Time    2016-9-25 Fixed lunar LeapMonth Param Bug
* @Time    2017-7-24 Fixed use getTerm Func Param Error.use solar year,NOT lunar year
* @Version 1.0.3
* @公历转农历:calendar.solar2lunar(1987,11,01); //[you can ignore params of prefix 0]
* @农历转公历:calendar.lunar2solar(1987,09,10); //[you can ignore params of prefix 0]
*/
/* eslint-disable */
var calendar = {

  /**
      * 农历1900-2100的润大小信息表
      * @Array Of Property
      * @return Hex
      */
  lunarInfo: [0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0, 0x09ad0, 0x055d2, // 1900-1909
    0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255, 0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977, // 1910-1919
    0x04970, 0x0a4b0, 0x0b4b5, 0x06a50, 0x06d40, 0x1ab54, 0x02b60, 0x09570, 0x052f2, 0x04970, // 1920-1929
    0x06566, 0x0d4a0, 0x0ea50, 0x06e95, 0x05ad0, 0x02b60, 0x186e3, 0x092e0, 0x1c8d7, 0x0c950, // 1930-1939
    0x0d4a0, 0x1d8a6, 0x0b550, 0x056a0, 0x1a5b4, 0x025d0, 0x092d0, 0x0d2b2, 0x0a950, 0x0b557, // 1940-1949
    0x06ca0, 0x0b550, 0x15355, 0x04da0, 0x0a5b0, 0x14573, 0x052b0, 0x0a9a8, 0x0e950, 0x06aa0, // 1950-1959
    0x0aea6, 0x0ab50, 0x04b60, 0x0aae4, 0x0a570, 0x05260, 0x0f263, 0x0d950, 0x05b57, 0x056a0, // 1960-1969
    0x096d0, 0x04dd5, 0x04ad0, 0x0a4d0, 0x0d4d4, 0x0d250, 0x0d558, 0x0b540, 0x0b6a0, 0x195a6, // 1970-1979
    0x095b0, 0x049b0, 0x0a974, 0x0a4b0, 0x0b27a, 0x06a50, 0x06d40, 0x0af46, 0x0ab60, 0x09570, // 1980-1989
    0x04af5, 0x04970, 0x064b0, 0x074a3, 0x0ea50, 0x06b58, 0x05ac0, 0x0ab60, 0x096d5, 0x092e0, // 1990-1999
    0x0c960, 0x0d954, 0x0d4a0, 0x0da50, 0x07552, 0x056a0, 0x0abb7, 0x025d0, 0x092d0, 0x0cab5, // 2000-2009
    0x0a950, 0x0b4a0, 0x0baa4, 0x0ad50, 0x055d9, 0x04ba0, 0x0a5b0, 0x15176, 0x052b0, 0x0a930, // 2010-2019
    0x07954, 0x06aa0, 0x0ad50, 0x05b52, 0x04b60, 0x0a6e6, 0x0a4e0, 0x0d260, 0x0ea65, 0x0d530, // 2020-2029
    0x05aa0, 0x076a3, 0x096d0, 0x04afb, 0x04ad0, 0x0a4d0, 0x1d0b6, 0x0d250, 0x0d520, 0x0dd45, // 2030-2039
    0x0b5a0, 0x056d0, 0x055b2, 0x049b0, 0x0a577, 0x0a4b0, 0x0aa50, 0x1b255, 0x06d20, 0x0ada0, // 2040-2049
    /** Add By JJonline@JJonline.Cn**/
    0x14b63, 0x09370, 0x049f8, 0x04970, 0x064b0, 0x168a6, 0x0ea50, 0x06b20, 0x1a6c4, 0x0aae0, // 2050-2059
    0x0a2e0, 0x0d2e3, 0x0c960, 0x0d557, 0x0d4a0, 0x0da50, 0x05d55, 0x056a0, 0x0a6d0, 0x055d4, // 2060-2069
    0x052d0, 0x0a9b8, 0x0a950, 0x0b4a0, 0x0b6a6, 0x0ad50, 0x055a0, 0x0aba4, 0x0a5b0, 0x052b0, // 2070-2079
    0x0b273, 0x06930, 0x07337, 0x06aa0, 0x0ad50, 0x14b55, 0x04b60, 0x0a570, 0x054e4, 0x0d160, // 2080-2089
    0x0e968, 0x0d520, 0x0daa0, 0x16aa6, 0x056d0, 0x04ae0, 0x0a9d4, 0x0a2d0, 0x0d150, 0x0f252, // 2090-2099
    0x0d520], // 2100

  /**
      * 公历每个月份的天数普通表
      * @Array Of Property
      * @return Number
      */
  solarMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],

  /**
      * 天干地支之天干速查表
      * @Array Of Property trans["甲","乙","丙","丁","戊","己","庚","辛","壬","癸"]
      * @return Cn string
      */
  Gan: ['\u7532', '\u4e59', '\u4e19', '\u4e01', '\u620a', '\u5df1', '\u5e9a', '\u8f9b', '\u58ec', '\u7678'],

  /**
      * 天干地支之地支速查表
      * @Array Of Property
      * @trans["子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"]
      * @return Cn string
      */
  Zhi: ['\u5b50', '\u4e11', '\u5bc5', '\u536f', '\u8fb0', '\u5df3', '\u5348', '\u672a', '\u7533', '\u9149', '\u620c', '\u4ea5'],

  /**
      * 天干地支之地支速查表<=>生肖
      * @Array Of Property
      * @trans["鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪"]
      * @return Cn string
      */
  Animals: ['\u9f20', '\u725b', '\u864e', '\u5154', '\u9f99', '\u86c7', '\u9a6c', '\u7f8a', '\u7334', '\u9e21', '\u72d7', '\u732a'],

  /**
      * 24节气速查表
      * @Array Of Property
      * @trans["小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至"]
      * @return Cn string
      */
  solarTerm: ['\u5c0f\u5bd2', '\u5927\u5bd2', '\u7acb\u6625', '\u96e8\u6c34', '\u60ca\u86f0', '\u6625\u5206', '\u6e05\u660e', '\u8c37\u96e8', '\u7acb\u590f', '\u5c0f\u6ee1', '\u8292\u79cd', '\u590f\u81f3', '\u5c0f\u6691', '\u5927\u6691', '\u7acb\u79cb', '\u5904\u6691', '\u767d\u9732', '\u79cb\u5206', '\u5bd2\u9732', '\u971c\u964d', '\u7acb\u51ac', '\u5c0f\u96ea', '\u5927\u96ea', '\u51ac\u81f3'],

  /**
      * 1900-2100各年的24节气日期速查表
      * @Array Of Property
      * @return 0x string For splice
      */
  sTermInfo: ['9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf97c3598082c95f8c965cc920f',
    '97bd0b06bdb0722c965ce1cfcc920f', 'b027097bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
    '97bcf97c359801ec95f8c965cc920f', '97bd0b06bdb0722c965ce1cfcc920f', 'b027097bd097c36b0b6fc9274c91aa',
    '97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f', '97bd0b06bdb0722c965ce1cfcc920f',
    'b027097bd097c36b0b6fc9274c91aa', '9778397bd19801ec9210c965cc920e', '97b6b97bd19801ec95f8c965cc920f',
    '97bd09801d98082c95f8e1cfcc920f', '97bd097bd097c36b0b6fc9210c8dc2', '9778397bd197c36c9210c9274c91aa',
    '97b6b97bd19801ec95f8c965cc920e', '97bd09801d98082c95f8e1cfcc920f', '97bd097bd097c36b0b6fc9210c8dc2',
    '9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec95f8c965cc920e', '97bcf97c3598082c95f8e1cfcc920f',
    '97bd097bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec9210c965cc920e',
    '97bcf97c3598082c95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b97bd19801ec9210c965cc920e', '97bcf97c3598082c95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722',
    '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f',
    '97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
    '97bcf97c359801ec95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f', '97bd097bd07f595b0b6fc920fb0722',
    '9778397bd097c36b0b6fc9210c8dc2', '9778397bd19801ec9210c9274c920e', '97b6b97bd19801ec95f8c965cc920f',
    '97bd07f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c920e',
    '97b6b97bd19801ec95f8c965cc920f', '97bd07f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2',
    '9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bd07f1487f595b0b0bc920fb0722',
    '7f0e397bd097c36b0b6fc9210c8dc2', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
    '97bcf7f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b97bd19801ec9210c965cc920e', '97bcf7f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
    '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf7f1487f531b0b0bb0b6fb0722',
    '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
    '97bcf7f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b97bd19801ec9210c9274c920e', '97bcf7f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
    '9778397bd097c36b0b6fc9210c91aa', '97b6b97bd197c36c9210c9274c920e', '97bcf7f0e47f531b0b0bb0b6fb0722',
    '7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c920e',
    '97b6b7f0e47f531b0723b0b6fb0722', '7f0e37f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2',
    '9778397bd097c36b0b70c9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721', '7f0e37f1487f595b0b0bb0b6fb0722',
    '7f0e397bd097c35b0b6fc9210c8dc2', '9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721',
    '7f0e27f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
    '9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
    '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721',
    '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
    '97b6b7f0e47f531b0723b0787b0721', '7f0e27f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
    '9778397bd097c36b0b6fc9210c91aa', '97b6b7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
    '7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9210c8dc2', '977837f0e37f149b0723b0787b0721',
    '7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f5307f595b0b0bc920fb0722', '7f0e397bd097c35b0b6fc9210c8dc2',
    '977837f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e37f1487f595b0b0bb0b6fb0722',
    '7f0e397bd097c35b0b6fc9210c8dc2', '977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
    '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '977837f0e37f14998082b0787b06bd',
    '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
    '977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
    '7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
    '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14998082b0787b06bd',
    '7f07e7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
    '977837f0e37f14998082b0723b06bd', '7f07e7f0e37f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
    '7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b0721',
    '7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f1487f595b0b0bb0b6fb0722', '7f0e37f0e37f14898082b0723b02d5',
    '7ec967f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f1487f531b0b0bb0b6fb0722',
    '7f0e37f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
    '7f0e37f1487f531b0b0bb0b6fb0722', '7f0e37f0e37f14898082b072297c35', '7ec967f0e37f14998082b0787b06bd',
    '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e37f0e37f14898082b072297c35',
    '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
    '7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f149b0723b0787b0721',
    '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14998082b0723b06bd',
    '7f07e7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722', '7f0e37f0e366aa89801eb072297c35',
    '7ec967f0e37f14998082b0723b06bd', '7f07e7f0e37f14998083b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
    '7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14898082b0723b02d5', '7f07e7f0e37f14998082b0787b0721',
    '7f07e7f0e47f531b0723b0b6fb0722', '7f0e36665b66aa89801e9808297c35', '665f67f0e37f14898082b0723b02d5',
    '7ec967f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0722', '7f0e36665b66a449801e9808297c35',
    '665f67f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
    '7f0e36665b66a449801e9808297c35', '665f67f0e37f14898082b072297c35', '7ec967f0e37f14998082b0787b06bd',
    '7f07e7f0e47f531b0723b0b6fb0721', '7f0e26665b66a449801e9808297c35', '665f67f0e37f1489801eb072297c35',
    '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722'],

  /**
      * 数字转中文速查表
      * @Array Of Property
      * @trans ['日','一','二','三','四','五','六','七','八','九','十']
      * @return Cn string
      */
  nStr1: ['\u65e5', '\u4e00', '\u4e8c', '\u4e09', '\u56db', '\u4e94', '\u516d', '\u4e03', '\u516b', '\u4e5d', '\u5341'],

  /**
      * 日期转农历称呼速查表
      * @Array Of Property
      * @trans ['初','十','廿','卅']
      * @return Cn string
      */
  nStr2: ['\u521d', '\u5341', '\u5eff', '\u5345'],

  /**
      * 月份转农历称呼速查表
      * @Array Of Property
      * @trans ['正','一','二','三','四','五','六','七','八','九','十','冬','腊']
      * @return Cn string
      */
  nStr3: ['\u6b63', '\u4e8c', '\u4e09', '\u56db', '\u4e94', '\u516d', '\u4e03', '\u516b', '\u4e5d', '\u5341', '\u51ac', '\u814a'],

  /**
      * 返回农历y年一整年的总天数
      * @param lunar Year
      * @return Number
      * @eg:var count = calendar.lYearDays(1987) ;//count=387
      */
  lYearDays: function (y) {
    var i; var sum = 348
    for (i = 0x8000; i > 0x8; i >>= 1) { sum += (this.lunarInfo[y - 1900] & i) ? 1 : 0 }
    return (sum + this.leapDays(y))
  },

  /**
      * 返回农历y年闰月是哪个月;若y年没有闰月 则返回0
      * @param lunar Year
      * @return Number (0-12)
      * @eg:var leapMonth = calendar.leapMonth(1987) ;//leapMonth=6
      */
  leapMonth: function (y) { // 闰字编码 \u95f0
    return (this.lunarInfo[y - 1900] & 0xf)
  },

  /**
      * 返回农历y年闰月的天数 若该年没有闰月则返回0
      * @param lunar Year
      * @return Number (0、29、30)
      * @eg:var leapMonthDay = calendar.leapDays(1987) ;//leapMonthDay=29
      */
  leapDays: function (y) {
    if (this.leapMonth(y)) {
      return ((this.lunarInfo[y - 1900] & 0x10000) ? 30 : 29)
    }
    return (0)
  },

  /**
      * 返回农历y年m月(非闰月)的总天数,计算m为闰月时的天数请使用leapDays方法
      * @param lunar Year
      * @return Number (-1、29、30)
      * @eg:var MonthDay = calendar.monthDays(1987,9) ;//MonthDay=29
      */
  monthDays: function (y, m) {
    if (m > 12 || m < 1) { return -1 }// 月份参数从1至12,参数错误返回-1
    return ((this.lunarInfo[y - 1900] & (0x10000 >> m)) ? 30 : 29)
  },

  /**
      * 返回公历(!)y年m月的天数
      * @param solar Year
      * @return Number (-1、28、29、30、31)
      * @eg:var solarMonthDay = calendar.leapDays(1987) ;//solarMonthDay=30
      */
  solarDays: function (y, m) {
    if (m > 12 || m < 1) { return -1 } // 若参数错误 返回-1
    var ms = m - 1
    if (ms == 1) { // 2月份的闰平规律测算后确认返回28或29
      return (((y % 4 == 0) && (y % 100 != 0) || (y % 400 == 0)) ? 29 : 28)
    } else {
      return (this.solarMonth[ms])
    }
  },

  /**
     * 农历年份转换为干支纪年
     * @param  lYear 农历年的年份数
     * @return Cn string
     */
  toGanZhiYear: function (lYear) {
    var ganKey = (lYear - 3) % 10
    var zhiKey = (lYear - 3) % 12
    if (ganKey == 0) ganKey = 10// 如果余数为0则为最后一个天干
    if (zhiKey == 0) zhiKey = 12// 如果余数为0则为最后一个地支
    return this.Gan[ganKey - 1] + this.Zhi[zhiKey - 1]
  },

  /**
     * 公历月、日判断所属星座
     * @param  cMonth [description]
     * @param  cDay [description]
     * @return Cn string
     */
  toAstro: function (cMonth, cDay) {
    var s = '\u9b54\u7faf\u6c34\u74f6\u53cc\u9c7c\u767d\u7f8a\u91d1\u725b\u53cc\u5b50\u5de8\u87f9\u72ee\u5b50\u5904\u5973\u5929\u79e4\u5929\u874e\u5c04\u624b\u9b54\u7faf'
    var arr = [20, 19, 21, 21, 21, 22, 23, 23, 23, 23, 22, 22]
    return s.substr(cMonth * 2 - (cDay < arr[cMonth - 1] ? 2 : 0), 2) + '\u5ea7'// 座
  },

  /**
      * 传入offset偏移量返回干支
      * @param offset 相对甲子的偏移量
      * @return Cn string
      */
  toGanZhi: function (offset) {
    return this.Gan[offset % 10] + this.Zhi[offset % 12]
  },

  /**
      * 传入公历(!)y年获得该年第n个节气的公历日期
      * @param y公历年(1900-2100);n二十四节气中的第几个节气(1~24);从n=1(小寒)算起
      * @return day Number
      * @eg:var _24 = calendar.getTerm(1987,3) ;//_24=4;意即1987年2月4日立春
      */
  getTerm: function (y, n) {
    if (y < 1900 || y > 2100) { return -1 }
    if (n < 1 || n > 24) { return -1 }
    var _table = this.sTermInfo[y - 1900]
    var _info = [
      parseInt('0x' + _table.substr(0, 5)).toString(),
      parseInt('0x' + _table.substr(5, 5)).toString(),
      parseInt('0x' + _table.substr(10, 5)).toString(),
      parseInt('0x' + _table.substr(15, 5)).toString(),
      parseInt('0x' + _table.substr(20, 5)).toString(),
      parseInt('0x' + _table.substr(25, 5)).toString()
    ]
    var _calday = [
      _info[0].substr(0, 1),
      _info[0].substr(1, 2),
      _info[0].substr(3, 1),
      _info[0].substr(4, 2),

      _info[1].substr(0, 1),
      _info[1].substr(1, 2),
      _info[1].substr(3, 1),
      _info[1].substr(4, 2),

      _info[2].substr(0, 1),
      _info[2].substr(1, 2),
      _info[2].substr(3, 1),
      _info[2].substr(4, 2),

      _info[3].substr(0, 1),
      _info[3].substr(1, 2),
      _info[3].substr(3, 1),
      _info[3].substr(4, 2),

      _info[4].substr(0, 1),
      _info[4].substr(1, 2),
      _info[4].substr(3, 1),
      _info[4].substr(4, 2),

      _info[5].substr(0, 1),
      _info[5].substr(1, 2),
      _info[5].substr(3, 1),
      _info[5].substr(4, 2)
    ]
    return parseInt(_calday[n - 1])
  },

  /**
      * 传入农历数字月份返回汉语通俗表示法
      * @param lunar month
      * @return Cn string
      * @eg:var cnMonth = calendar.toChinaMonth(12) ;//cnMonth='腊月'
      */
  toChinaMonth: function (m) { // 月 => \u6708
    if (m > 12 || m < 1) { return -1 } // 若参数错误 返回-1
    var s = this.nStr3[m - 1]
    s += '\u6708'// 加上月字
    return s
  },

  /**
      * 传入农历日期数字返回汉字表示法
      * @param lunar day
      * @return Cn string
      * @eg:var cnDay = calendar.toChinaDay(21) ;//cnMonth='廿一'
      */
  toChinaDay: function (d) { // 日 => \u65e5
    var s
    switch (d) {
      case 10:
        s = '\u521d\u5341'; break
      case 20:
        s = '\u4e8c\u5341'; break
        break
      case 30:
        s = '\u4e09\u5341'; break
        break
      default :
        s = this.nStr2[Math.floor(d / 10)]
        s += this.nStr1[d % 10]
    }
    return (s)
  },

  /**
      * 年份转生肖[!仅能大致转换] => 精确划分生肖分界线是“立春”
      * @param y year
      * @return Cn string
      * @eg:var animal = calendar.getAnimal(1987) ;//animal='兔'
      */
  getAnimal: function (y) {
    return this.Animals[(y - 4) % 12]
  },

  /**
      * 传入阳历年月日获得详细的公历、农历object信息 <=>JSON
      * @param y  solar year
      * @param m  solar month
      * @param d  solar day
      * @return JSON object
      * @eg:console.log(calendar.solar2lunar(1987,11,01));
      */
  solar2lunar: function (y, m, d) { // 参数区间1900.1.31~2100.12.31
    // 年份限定、上限
    if (y < 1900 || y > 2100) {
      return -1// undefined转换为数字变为NaN
    }
    // 公历传参最下限
    if (y == 1900 && m == 1 && d < 31) {
      return -1
    }
    // 未传参  获得当天
    if (!y) {
      var objDate = new Date()
    } else {
      var objDate = new Date(y, parseInt(m) - 1, d)
    }
    var i; var leap = 0; var temp = 0
    // 修正ymd参数
    var y = objDate.getFullYear()
    var m = objDate.getMonth() + 1
    var d = objDate.getDate()
    var offset = (Date.UTC(objDate.getFullYear(), objDate.getMonth(), objDate.getDate()) - Date.UTC(1900, 0, 31)) / 86400000
    for (i = 1900; i < 2101 && offset > 0; i++) {
      temp = this.lYearDays(i)
      offset -= temp
    }
    if (offset < 0) {
      offset += temp; i--
    }

    // 是否今天
    var isTodayObj = new Date()
    var isToday = false
    if (isTodayObj.getFullYear() == y && isTodayObj.getMonth() + 1 == m && isTodayObj.getDate() == d) {
      isToday = true
    }
    // 星期几
    var nWeek = objDate.getDay()
    var cWeek = this.nStr1[nWeek]
    // 数字表示周几顺应天朝周一开始的惯例
    if (nWeek == 0) {
      nWeek = 7
    }
    // 农历年
    var year = i
    var leap = this.leapMonth(i) // 闰哪个月
    var isLeap = false

    // 效验闰月
    for (i = 1; i < 13 && offset > 0; i++) {
      // 闰月
      if (leap > 0 && i == (leap + 1) && isLeap == false) {
        --i
        isLeap = true; temp = this.leapDays(year) // 计算农历闰月天数
      } else {
        temp = this.monthDays(year, i)// 计算农历普通月天数
      }
      // 解除闰月
      if (isLeap == true && i == (leap + 1)) { isLeap = false }
      offset -= temp
    }
    // 闰月导致数组下标重叠取反
    if (offset == 0 && leap > 0 && i == leap + 1) {
      if (isLeap) {
        isLeap = false
      } else {
        isLeap = true; --i
      }
    }
    if (offset < 0) {
      offset += temp; --i
    }
    // 农历月
    var month = i
    // 农历日
    var day = offset + 1
    // 天干地支处理
    var sm = m - 1
    var gzY = this.toGanZhiYear(year)

    // 当月的两个节气
    // bugfix-2017-7-24 11:03:38 use lunar Year Param `y` Not `year`
    var firstNode = this.getTerm(y, (m * 2 - 1))// 返回当月「节」为几日开始
    var secondNode = this.getTerm(y, (m * 2))// 返回当月「节」为几日开始

    // 依据12节气修正干支月
    var gzM = this.toGanZhi((y - 1900) * 12 + m + 11)
    if (d >= firstNode) {
      gzM = this.toGanZhi((y - 1900) * 12 + m + 12)
    }

    // 传入的日期的节气与否
    var isTerm = false
    var Term = null
    if (firstNode == d) {
      isTerm = true
      Term = this.solarTerm[m * 2 - 2]
    }
    if (secondNode == d) {
      isTerm = true
      Term = this.solarTerm[m * 2 - 1]
    }
    // 日柱 当月一日与 1900/1/1 相差天数
    var dayCyclical = Date.UTC(y, sm, 1, 0, 0, 0, 0) / 86400000 + 25567 + 10
    var gzD = this.toGanZhi(dayCyclical + d - 1)
    // 该日期所属的星座
    var astro = this.toAstro(m, d)

    return { 'lYear': year, 'lMonth': month, 'lDay': day, 'Animal': this.getAnimal(year), 'IMonthCn': (isLeap ? '\u95f0' : '') + this.toChinaMonth(month), 'IDayCn': this.toChinaDay(day), 'cYear': y, 'cMonth': m, 'cDay': d, 'gzYear': gzY, 'gzMonth': gzM, 'gzDay': gzD, 'isToday': isToday, 'isLeap': isLeap, 'nWeek': nWeek, 'ncWeek': '\u661f\u671f' + cWeek, 'isTerm': isTerm, 'Term': Term, 'astro': astro }
  },

  /**
      * 传入农历年月日以及传入的月份是否闰月获得详细的公历、农历object信息 <=>JSON
      * @param y  lunar year
      * @param m  lunar month
      * @param d  lunar day
      * @param isLeapMonth  lunar month is leap or not.[如果是农历闰月第四个参数赋值true即可]
      * @return JSON object
      * @eg:console.log(calendar.lunar2solar(1987,9,10));
      */
  lunar2solar: function (y, m, d, isLeapMonth) { // 参数区间1900.1.31~2100.12.1
    var isLeapMonth = !!isLeapMonth
    var leapOffset = 0
    var leapMonth = this.leapMonth(y)
    var leapDay = this.leapDays(y)
    if (isLeapMonth && (leapMonth != m)) { return -1 }// 传参要求计算该闰月公历 但该年得出的闰月与传参的月份并不同
    if (y == 2100 && m == 12 && d > 1 || y == 1900 && m == 1 && d < 31) { return -1 }// 超出了最大极限值
    var day = this.monthDays(y, m)
    var _day = day
    // bugFix 2016-9-25
    // if month is leap, _day use leapDays method
    if (isLeapMonth) {
      _day = this.leapDays(y, m)
    }
    if (y < 1900 || y > 2100 || d > _day) { return -1 }// 参数合法性效验

    // 计算农历的时间差
    var offset = 0
    for (var i = 1900; i < y; i++) {
      offset += this.lYearDays(i)
    }
    var leap = 0; var isAdd = false
    for (var i = 1; i < m; i++) {
      leap = this.leapMonth(y)
      if (!isAdd) { // 处理闰月
        if (leap <= i && leap > 0) {
          offset += this.leapDays(y); isAdd = true
        }
      }
      offset += this.monthDays(y, i)
    }
    // 转换闰月农历 需补充该年闰月的前一个月的时差
    if (isLeapMonth) { offset += day }
    // 1900年农历正月一日的公历时间为1900年1月30日0时0分0秒(该时间也是本农历的最开始起始点)
    var stmap = Date.UTC(1900, 1, 30, 0, 0, 0)
    var calObj = new Date((offset + d - 31) * 86400000 + stmap)
    var cY = calObj.getUTCFullYear()
    var cM = calObj.getUTCMonth() + 1
    var cD = calObj.getUTCDate()

    return this.solar2lunar(cY, cM, cD)
  }
}

export default calendar
好了,整个关键 js 文件都放上来了,不需要找我要源码啦,

本文结束
本文来自投稿,不代表站三界导航立场,如若转载,请注明出处:https://www.zhansanjie.com/article/details/42331.html

版权声明:

1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

2、本站仅提供信息发布平台,不承担相关法律责任。

3、若侵犯您的版权或隐私,请联系本站管理员删除。

4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。

分享
站三界导航
本站声明:本站严格遵守国家相关法律规定,非正规网站一概不予收录。本站所有资料取之于互联网,任何公司或个人参考使用本资料请自辨真伪、后果自负,站三界导航不承担任何责任。在此特别感谢您对站三界导航的支持与厚爱。