(javascript)常用农历(12生肖年,天干地支,节气)

今天碰到页面需要加上农历和公历同时显示的功能要求,搜索下网络,找到一个网页不过现在找不到地址了。希望给大家一点帮助。
贴代码如下:
None.gif // --------------------显示中国农历---------------------
None.gif//
-------------  create date:2007-10-9 ----------------
None.gif//
-------------     call  example      ----------------
None.gif//
显示当前时间
None.gif//
function setCalendar()
None.gif//
{
None.gif//
    document.write("<table border='1' cellspacing='3' width='180' bordercolor='#009B00' bgcolor='#FFFFFF' height='110' cellpadding='2'");
None.gif//
    document.write("<tr><td align='center'><b>"+YYMMDD());
None.gif//
    document.write(weekday());
None.gif//
    document.write("<br>"+solarDay2()+"</td></tr></table>");
None.gif//
}
None.gif//
-------------            end   example             ----------------
None.gif

ExpandedBlockStart.gifContractedBlock.gif
var  lunarInfo = new  Array( /**/ /* 1900 */
None.gif
0x04bd8 , 0x04ae0 , 0x0a570 , 0x054d5 , 0x0d260 , 0x0d950 , 0x16554 , 0x056a0 , 0x09ad0 , 0x055d2 ,
None.gif
0x04ae0 , 0x0a5b6 , 0x0a4d0 , 0x0d250 , 0x1d255 , 0x0b540 , 0x0d6a0 , 0x0ada2 , 0x095b0 , 0x14977 ,
None.gif
0x04970 , 0x0a4b0 , 0x0b4b5 , 0x06a50 , 0x06d40 , 0x1ab54 , 0x02b60 , 0x09570 , 0x052f2 , 0x04970 ,
None.gif
0x06566 , 0x0d4a0 , 0x0ea50 , 0x06e95 , 0x05ad0 , 0x02b60 , 0x186e3 , 0x092e0 , 0x1c8d7 , 0x0c950 ,
None.gif
0x0d4a0 , 0x1d8a6 , 0x0b550 , 0x056a0 , 0x1a5b4 , 0x025d0 , 0x092d0 , 0x0d2b2 , 0x0a950 , 0x0b557 ,
None.gif
0x06ca0 , 0x0b550 , 0x15355 , 0x04da0 , 0x0a5d0 , 0x14573 , 0x052d0 , 0x0a9a8 , 0x0e950 , 0x06aa0 ,
None.gif
0x0aea6 , 0x0ab50 , 0x04b60 , 0x0aae4 , 0x0a570 , 0x05260 , 0x0f263 , 0x0d950 , 0x05b57 , 0x056a0 ,
None.gif
0x096d0 , 0x04dd5 , 0x04ad0 , 0x0a4d0 , 0x0d4d4 , 0x0d250 , 0x0d558 , 0x0b540 , 0x0b5a0 , 0x195a6 ,
None.gif
0x095b0 , 0x049b0 , 0x0a974 , 0x0a4b0 , 0x0b27a , 0x06a50 , 0x06d40 , 0x0af46 , 0x0ab60 , 0x09570 ,
None.gif
0x04af5 , 0x04970 , 0x064b0 , 0x074a3 , 0x0ea50 , 0x06b58 , 0x055c0 , 0x0ab60 , 0x096d5 , 0x092e0 ,
None.gif
0x0c960 , 0x0d954 , 0x0d4a0 , 0x0da50 , 0x07552 , 0x056a0 , 0x0abb7 , 0x025d0 , 0x092d0 , 0x0cab5 ,
None.gif
0x0a950 , 0x0b4a0 , 0x0baa4 , 0x0ad50 , 0x055d9 , 0x04ba0 , 0x0a5b0 , 0x15176 , 0x052b0 , 0x0a930 ,
None.gif
0x07954 , 0x06aa0 , 0x0ad50 , 0x05b52 , 0x04b60 , 0x0a6e6 , 0x0a4e0 , 0x0d260 , 0x0ea65 , 0x0d530 ,
None.gif
0x05aa0 , 0x076a3 , 0x096d0 , 0x04bd7 , 0x04ad0 , 0x0a4d0 , 0x1d0b6 , 0x0d250 , 0x0d520 , 0x0dd45 ,
ExpandedBlockStart.gifContractedBlock.gif
0x0b5a0 , 0x056d0 , 0x055b2 , 0x049b0 , 0x0a577 , 0x0a4b0 , 0x0aa50 , 0x1b255 , 0x06d20 , 0x0ada0 , /**/ /* 2049 */
None.gif
// 下面的是从 2050 到 2100 年的
ExpandedBlockStart.gifContractedBlock.gif
0x14b63 /**/ /* 2050 */
ExpandedBlockStart.gifContractedBlock.gif
0x09370 0x049f8 0x04970 0x064b0 0x168a6 /**/ /* 2055 */
ExpandedBlockStart.gifContractedBlock.gif
0x0ea50 0x06b20 0x1a6c4 0x0aae0 0x0a2e0 /**/ /* 2060 */
ExpandedBlockStart.gifContractedBlock.gif
0x0d2e3 0x0c960 0x0d557 0x0d4a0 0x0da50 /**/ /* 2065 */
ExpandedBlockStart.gifContractedBlock.gif
0x05d55 0x056a0 0x0a6d0 0x055d4 0x052d0 /**/ /* 2070 */
ExpandedBlockStart.gifContractedBlock.gif
0x0a9b8 0x0a950 0x0a4a0 0x0b6a6 0x0ad50 /**/ /* 2075 */
ExpandedBlockStart.gifContractedBlock.gif
0x055a0 0x0aba0 0x0a5b0 0x052b0 0x0b273 /**/ /* 2080 */
ExpandedBlockStart.gifContractedBlock.gif
0x06930 0x07337 0x06aa0 0x0ad50 0x14b55 /**/ /* 2085 */
ExpandedBlockStart.gifContractedBlock.gif
0x04b60 0x0a570 0x054e4 0x0d260 0x0e968 /**/ /* 2090 */
ExpandedBlockStart.gifContractedBlock.gif
0x0d520 0x0daa0 0x16aa6 0x056d0 0x04ae0 /**/ /* 2095 */
ExpandedBlockStart.gifContractedBlock.gif
0x0a9d4 0x0a4d0 0x0d150 0x0f252 0x0d520   /**/ /* 2100 */
None.gif);
None.gif
var  Animals = new  Array( " " , " " , " " , " " , " " , " " , " " , " " , " " , " " , " " , " " );
None.gif
var  Gan = new  Array( " " , " " , " " , " " , " " , " " , " " , " " , " " , " " );
None.gif
var  Zhi = new  Array( " " , " " , " " , " " , " " , " " , " " , " " , " " , " " , " " , " " );
None.gif
var  now  =   new  Date();
None.gif
var  SY  =  now.getYear();
None.gif
var  SM  =  now.getMonth();
None.gif
var  SD  =  now.getDate();
None.gif
// ==== 传入 offset 传回干支, 0=甲子
None.gif
function  cyclical(num)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif  
return(Gan[num%10]+Zhi[num%12]);
ExpandedBlockEnd.gif}

None.gif
// ==== 传回农历 y年的总天数
None.gif
function  lYearDays(y)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif   
var i, sum = 348;
InBlock.gif   
for(i=0x8000; i>0x8; i>>=1) sum += (lunarInfo[y-1900& i) ? 1 : 0;
InBlock.gif   
return(sum+leapDays(y));
ExpandedBlockEnd.gif}

None.gif
// ==== 传回农历 y年闰月的天数
None.gif
function  leapDays(y)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif   
if(leapMonth(y))  return((lunarInfo[y-1900& 0x10000? 30 : 29);
InBlock.gif   
else return(0);
ExpandedBlockEnd.gif}

None.gif
// ==== 传回农历 y年闰哪个月 1-12 , 没闰传回 0
None.gif
function  leapMonth(y)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif  
return(lunarInfo[y-1900& 0xf);
ExpandedBlockEnd.gif}

None.gif
None.gif
// ====================================== 传回农历 y年m月的总天数
None.gif
function  monthDays(y, m)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif  
return (lunarInfo[y-1900& (0x10000>>m))? 30 : 29;
ExpandedBlockEnd.gif}

None.gif
None.gif
// ==== 算出农历, 传入日期物件, 传回农历日期物件
None.gif//
==== 该物件属性有 .year .month .day .isLeap .yearCyl .dayCyl .monCyl
None.gif
function  Lunar(objDate)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif   
var i, leap=0, temp=0;
InBlock.gif   
var baseDate = new Date(1900,0,31);
InBlock.gif   
var offset = (objDate - baseDate)/86400000;
InBlock.gif
InBlock.gif   
this.dayCyl = offset + 40;
InBlock.gif   
this.monCyl = 14;
InBlock.gif
InBlock.gif   
for (i = 1900; i<2050 && offset>0; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
InBlock.gif      temp 
= lYearDays(i);
InBlock.gif      offset 
-= temp;
InBlock.gif      
this.monCyl += 12;
ExpandedSubBlockEnd.gif   }

InBlock.gif   
if (offset < 0)
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
InBlock.gif      offset 
+= temp;
InBlock.gif      i
--;
InBlock.gif      
this.monCyl -= 12;
ExpandedSubBlockEnd.gif   }

InBlock.gif
InBlock.gif   
this.year = i;
InBlock.gif   
this.yearCyl = i-1864;
InBlock.gif
InBlock.gif   leap 
= leapMonth(i); //闰哪个月
InBlock.gif
   this.isLeap = false;
InBlock.gif
InBlock.gif   
for (i = 1; i < 13 && offset > 0; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
InBlock.gif      
//闰月
InBlock.gif
      if (leap > 0 && i == (leap+1&& this.isLeap == false)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif          
--i;
InBlock.gif          
this.isLeap = true;
InBlock.gif          temp 
= leapDays(this.year);
ExpandedSubBlockEnd.gif      }

InBlock.gif      
else
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif         temp 
= monthDays(this.year, i);
ExpandedSubBlockEnd.gif      }

InBlock.gif
InBlock.gif      
//解除闰月
InBlock.gif
      if (this.isLeap == true && i == (leap+1))
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif         
this.isLeap = false;
ExpandedSubBlockEnd.gif      }

InBlock.gif
InBlock.gif      offset 
-= temp;
InBlock.gif      
if (this.isLeap == false)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif         
this.monCyl++;
ExpandedSubBlockEnd.gif      }

ExpandedSubBlockEnd.gif   }

InBlock.gif
InBlock.gif   
if (offset == 0 && leap > 0 && i == leap + 1)
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
InBlock.gif      
if (this.isLeap)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        
this.isLeap = false;
ExpandedSubBlockEnd.gif      }

InBlock.gif      
else
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif        
this.isLeap = true;
InBlock.gif        
--i;
InBlock.gif        
--this.monCyl;
ExpandedSubBlockEnd.gif      }

ExpandedSubBlockEnd.gif   }

InBlock.gif
InBlock.gif   
if (offset < 0)
ExpandedSubBlockStart.gifContractedSubBlock.gif   
dot.gif{
InBlock.gif     offset 
+= temp;
InBlock.gif     
--i;
InBlock.gif     
--this.monCyl;
ExpandedSubBlockEnd.gif   }

InBlock.gif
InBlock.gif   
this.month = i;
InBlock.gif   
this.day = offset + 1;
ExpandedBlockEnd.gif}

None.gif
None.gif
function  YYMMDD()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
//var cl = '<font color="green" STYLE="font-size:13pt;">';
InBlock.gif
    //if (now.getDay() == 0) cl = '<font color="#c00000" STYLE="font-size:13pt;">';
InBlock.gif
   // if (now.getDay() == 6) cl = '<font color="green" STYLE="font-size:13pt;">';
InBlock.gif
    return(SY+'年'+(SM+1)+'月'+SD+'日   ');
ExpandedBlockEnd.gif}

None.gif
function  weekday()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
var day = new Array("星期日","星期一","星期二","星期三","星期四","星期五","星期六");
InBlock.gif   
// var cl = '<font color="green" STYLE="font-size:9pt;">';
InBlock.gif
   // if (now.getDay() == 0) cl = '<font color="green" STYLE="font-size:9pt;">';
InBlock.gif
   // if (now.getDay() == 6) cl = '<font color="red" STYLE="font-size:9pt;">';
InBlock.gif
    return(day[now.getDay()]+'  ');
ExpandedBlockEnd.gif}

None.gif
// ==== 中文日期
None.gif
function  cDay(m, d)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif  
var nStr1 = new Array('日','一','二','三','四','五','六','七','八','九','十');
InBlock.gif  
var nStr2 = new Array('初','十','廿','卅',' ');
InBlock.gif  
var s;
InBlock.gif  
if (m > 10)
ExpandedSubBlockStart.gifContractedSubBlock.gif  
dot.gif{
InBlock.gif    s 
= '十' + nStr1[m-10];
ExpandedSubBlockEnd.gif  }

InBlock.gif  
else
ExpandedSubBlockStart.gifContractedSubBlock.gif  
dot.gif{
InBlock.gif    s 
= nStr1[m];
ExpandedSubBlockEnd.gif  }

InBlock.gif  s 
+= '月';
InBlock.gif  
switch (d)
ExpandedSubBlockStart.gifContractedSubBlock.gif  
dot.gif{
InBlock.gif    
case 10:s += '初十'; break;
InBlock.gif    
case 20:s += '二十'; break;
InBlock.gif    
case 30:s += '三十'; break;
InBlock.gif    
default:s += nStr2[Math.floor(d/10)]; s += nStr1[d%10];
ExpandedSubBlockEnd.gif  }

InBlock.gif  
return(s);
ExpandedBlockEnd.gif}

None.gif
None.gif
//  12生肖
None.gif
function  solarDay1()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
var sDObj = new Date(SY, SM, SD);
InBlock.gif    
var lDObj = new Lunar(sDObj);
InBlock.gif    
var tt = '【' + Animals[(SY-4)%12+ '】' + cyclical(lDObj.monCyl) + '月 ' + cyclical(lDObj.dayCyl+++ '日';
InBlock.gif    
return(tt+'</font>');
ExpandedBlockEnd.gif}

None.gif
None.gif
// 天干地支
None.gif
function  solarDay2()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
var sDObj = new Date(SY, SM, SD);
InBlock.gif    
var lDObj = new Lunar(sDObj);
InBlock.gif    
var tt = cyclical(SY-1900+36)+'年 '+cDay(lDObj.month,lDObj.day);
InBlock.gif    
return(tt);
ExpandedBlockEnd.gif}

None.gif
None.gif
// 节气(  这里面还有样式!)
None.gif
function  solarDay3()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif  
var sTermInfo = new Array(0,21208,42467,63836,85337,107014,128867,150921,173149,195551,218072,240693,263343,285989,308563,331033,353350,375494,397447,419210,440795,462224,483532,504758);
InBlock.gif  
var solarTerm = new Array("小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑"," 大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至");
InBlock.gif  
var lFtv = new Array("0101*春节","0115 元宵节","0505 端午节","0707 七夕情人节","0715 中元节","0815 中秋节","0909 重阳节","1208 腊八节","1224 小年","0100*除夕");
InBlock.gif  
var sFtv = new Array("0101*元旦","0214 情人节","0308 妇女节","0312 植树节","0315 消费者权益日","0401 愚人节","0501 劳动节","0504 青年节","0512 护士节","0601 儿童节","0701 建党节 香港回归纪念","0801 建军节","0808 父亲节","0909 毛席逝世纪念","0910 教师节","0928 孔子诞辰","1001*国庆节","1006 老人节","1024 联合国日","1112 孙中山诞辰","1220 澳门回归纪念","1225 圣诞节","1226 毛席诞辰");
InBlock.gif
InBlock.gif  
var sDObj = new Date(SY, SM, SD);
InBlock.gif  
var lDObj = new Lunar(sDObj);
InBlock.gif  
var lDPOS = new Array(3);
InBlock.gif  
var festival='',solarTerms='',solarFestival='',lunarFestival='',tmp1,tmp2;
InBlock.gif  
//农历节日
InBlock.gif
  for (i in lFtv)
ExpandedSubBlockStart.gifContractedSubBlock.gif  
if (lFtv[i].match(/^(\ddot.gif{2})(.dot.gif{2})([\s\*])(.+)$/)) dot.gif{
InBlock.gif    tmp1
=Number(RegExp.$1)-lDObj.month;
InBlock.gif    tmp2
=Number(RegExp.$2)-lDObj.day;
InBlock.gif    
if(tmp1==0 && tmp2==0) lunarFestival=RegExp.$4;
ExpandedSubBlockEnd.gif  }

InBlock.gif  
//国历节日
InBlock.gif
  for (i in sFtv)
ExpandedSubBlockStart.gifContractedSubBlock.gif  
if (sFtv[i].match(/^(\ddot.gif{2})(\ddot.gif{2})([\s\*])(.+)$/))dot.gif{
InBlock.gif    tmp1 
= Number(RegExp.$1)-(SM+1);
InBlock.gif    tmp2 
= Number(RegExp.$2)-SD;
InBlock.gif    
if (tmp1==0 && tmp2==0) solarFestival = RegExp.$4;
ExpandedSubBlockEnd.gif  }

InBlock.gif  
//节气
InBlock.gif
  tmp1 = new Date((31556925974.7*(SY-1900)+sTermInfo[SM*2+1]*60000)+Date.UTC(1900,0,6,2,5));
InBlock.gif  tmp2 
= tmp1.getUTCDate();
InBlock.gif  
if (tmp2 == SD) solarTerms = solarTerm[SM*2+1];
InBlock.gif  tmp1 
= new Date((31556925974.7*(SY-1900)+sTermInfo[SM*2]*60000)+Date.UTC(1900,0,6,2,5));
InBlock.gif  tmp2 
= tmp1.getUTCDate();
InBlock.gif  
if (tmp2 == SD) solarTerms = solarTerm[SM*2];
InBlock.gif
InBlock.gif  
if (solarTerms == '' && solarFestival == '' && lunarFestival == '')
InBlock.gif    festival 
= '';
InBlock.gif  
else
InBlock.gif    festival 
= '<TABLE WIDTH=100% BORDER=0 CELLPADDING=2 CELLSPACING=0 BGCOLOR="#CCFFCC"><TR><TD align=center><marquee direction=left scrolldelay=120 behavior=alternate>'+
InBlock.gif    '
<FONT COLOR="#FF33FF" STYLE="font-size:9pt;"><b>+ solarTerms + ' ' + solarFestival + ' ' + lunarFestival + '</b></FONT>'+
InBlock.gif    '
</marquee></TD></TR></TABLE>';
InBlock.gif 
InBlock.gif  
return('<font color="green" STYLE="font-size:9pt;">'+festival+'</font>');
ExpandedBlockEnd.gif}

None.gif
None.gif
function  GetClientLunar()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif   document.write(YYMMDD() 
+ weekday() + solarDay2());
ExpandedBlockEnd.gif}

None.gif
None.gif
None.gif 

转载于:https://www.cnblogs.com/ocean2000/archive/2007/10/10/918895.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值