- 52浏览
- 2023-03-24
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 文件都放上来了,不需要找我要源码啦,
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。