<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML><HEAD><TITLE></TITLE>
<META http-equiv=Content-Type content=text/htmlcharset=gb2312>
<META
<META content=All name=robots>
<META content="Gregorian Solar Calendar and Chinese Lunar Calendar"
name=description>
<META content=no-cache name=Pragma>
<META content=no-cache name=Cache-Control>
<script language="JavaScript" src="jieri.js"></script>
<script language="JavaScript" src="jieqi.js"></script>
<SCRIPT language=JScript>
var conWeekend = 3
var lunarInfo=new Array(
0x4bd8,0x4ae0,0xa570,0x54d5,0xd260,0xd950,0x5554,0x56af,0x9ad0,0x55d2,
0x4ae0,0xa5b6,0xa4d0,0xd250,0xd295,0xb54f,0xd6a0,0xada2,0x95b0,0x4977,
0x497f,0xa4b0,0xb4b5,0x6a50,0x6d40,0xab54,0x2b6f,0x9570,0x52f2,0x4970,
0x6566,0xd4a0,0xea50,0x6a95,0x5adf,0x2b60,0x86e3,0x92ef,0xc8d7,0xc95f,
0xd4a0,0xd8a6,0xb55f,0x56a0,0xa5b4,0x25df,0x92d0,0xd2b2,0xa950,0xb557,
0x6ca0,0xb550,0x5355,0x4daf,0xa5b0,0x4573,0x52bf,0xa9a8,0xe950,0x6aa0,
0xaea6,0xab50,0x4b60,0xaae4,0xa570,0x5260,0xf263,0xd950,0x5b57,0x56a0,
0x96d0,0x4dd5,0x4ad0,0xa4d0,0xd4d4,0xd250,0xd558,0xb540,0xb6a0,0x95a6,
0x95bf,0x49b0,0xa974,0xa4b0,0xb27a,0x6a50,0x6d40,0xaf46,0xab60,0x9570,
0x4af5,0x4970,0x64b0,0x74a3,0xea50,0x6b58,0x5ac0,0xab60,0x96d5,0x92e0,
0xc960,0xd954,0xd4a0,0xda50,0x7552,0x56a0,0xabb7,0x25d0,0x92d0,0xcab5,
0xa950,0xb4a0,0xbaa4,0xad50,0x55d9,0x4ba0,0xa5b0,0x5176,0x52bf,0xa930,
0x7954,0x6aa0,0xad50,0x5b52,0x4b60,0xa6e6,0xa4e0,0xd260,0xea65,0xd530,
0x5aa0,0x76a3,0x96d0,0x4afb,0x4ad0,0xa4d0,0xd0b6,0xd25f,0xd520,0xdd45,
0xb5a0,0x56d0,0x55b2,0x49b0,0xa577,0xa4b0,0xaa50,0xb255,0x6d2f,0xada0,
0x4b63,0x937f,0x49f8,0x4970,0x64b0,0x68a6,0xea5f,0x6b20,0xa6c4,0xaaef,
0x92e0,0xd2e3,0xc960,0xd557,0xd4a0,0xda50,0x5d55,0x56a0,0xa6d0,0x55d4,
0x52d0,0xa9b8,0xa950,0xb4a0,0xb6a6,0xad50,0x55a0,0xaba4,0xa5b0,0x52b0,
0xb273,0x6930,0x7337,0x6aa0,0xad50,0x4b55,0x4b6f,0xa570,0x54e4,0xd260,
0xe968,0xd520,0xdaa0,0x6aa6,0x56df,0x4ae0,0xa9d4,0xa4d0,0xd150,0xf252,
0xd520)
var solarMonth=new Array(31,28,31,30,31,30,31,31,30,31,30,31)
var Gan=new Array("甲","乙","丙","丁","戊","己","庚","辛","壬","癸")
var Zhi=new Array("子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥")
var Animals=new Array("鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪")
var solarTerm = new Array("小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至")
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)
var nStr1 = new Array('日','一','二','三','四','五','六','七','八','九','十')
var nStr2 = new Array('初','十','廿','卅',' ')
var monthName = new Array("1 月","2 月","3 月","4 月","5 月","6 月","7 月","8 月","9 月","10 月","11 月","12 月")
var timeData = {
"Asia亚洲": { //----------------------------------------------
"Brunei 文莱 ":["+0800","","斯里巴加湾市"],
"Burma 缅甸 ":["+0630","","仰光"],
"Cambodia 柬埔寨 ":["+0700","","金边"],
"China 中国 ":["+0800","","北京、重庆、上海、天津"],
"China(HK,Macau) 中国 ":["+0800","","香港、澳门特区"],
"China(TaiWan) 中国 ":["+0800","","台北、高雄"],
"China(Urumchi) 中国 ":["+0700","","乌鲁木齐"],
"Indonesia 印尼 ":["+0700","","雅加达"],
"Poland 波兰 ":["+0100","","华沙"],
"国际换日线 ":["-1200","","国际换日线"]
}
}
function lYearDays(y) {
var i, sum = 348
for(i=0x8000i>0x8i>>=1) sum += (lunarInfo[y-1900] &i)? 1: 0
return(sum+leapDays(y))
}
function leapDays(y) {
if(leapMonth(y)) return( (lunarInfo[y-1899]&0xf)==0xf? 30: 29)
else return(0)
}
function leapMonth(y) {
var lm = lunarInfo[y-1900] &0xf
return(lm==0xf?0:lm)
}
function monthDays(y,m) {
return( (lunarInfo[y-1900] &(0x10000>>m))? 30: 29 )
}
function Lunar(objDate) {
var i, leap=0, temp=0
var baseDate = new Date(1900,0,31)
var offset = (objDate - baseDate)/86400000
this.dayCyl = offset + 40
this.monCyl = 14
for(i=1900i<2050 &&offset>0i++) {
temp = lYearDays(i)
offset -= temp
this.monCyl += 12
}
if(offset<0) {
offset += temp
i--
this.monCyl -= 12
}
this.year = i
this.yearCyl = i-1864
leap = leapMonth(i) //闰哪个月
this.isLeap = false
for(i=1i<13 &&offset>0i++) {
//闰月
if(leap>0 &&i==(leap+1) &&this.isLeap==false)
{ --ithis.isLeap = truetemp = leapDays(this.year)}
else
{ temp = monthDays(this.year, i)}
//解除闰月
if(this.isLeap==true &&i==(leap+1)) this.isLeap = false
offset -= temp
if(this.isLeap == false) this.monCyl ++
}
if(offset==0 &&leap>0 &&i==leap+1)
if(this.isLeap)
{ this.isLeap = false}
else
{ this.isLeap = true--i--this.monCyl}
if(offset<0){ offset += temp--i--this.monCyl}
this.month = i
this.day = offset + 1
}
function solarDays(y,m) {
if(m==1)
return(((y%4 == 0) &&(y%100 != 0) || (y%400 == 0))? 29: 28)
else
return(solarMonth[m])
}
function cyclical(num) {
return(Gan[num%10]+Zhi[num%12])
}
//============================== 阴历属性
function calElement(sYear,sMonth,sDay,week,lYear,lMonth,lDay,isLeap,cYear,cMonth,cDay) {
this.isToday = false
//瓣句
this.sYear = sYear //公元年4位数字
this.sMonth = sMonth//公元月数字
this.sDay= sDay //公元日数字
this.week= week //星期, 1个中文
//农历
this.lYear = lYear //公元年4位数字
this.lMonth = lMonth//农历月数字
this.lDay= lDay //农历日数字
this.isLeap = isLeap//是否为农历闰月?
//八字
this.cYear = cYear //年柱, 2个中文
this.cMonth = cMonth//月柱, 2个中文
this.cDay= cDay //日柱, 2个中文
this.color = ''
this.lunarFestival = ''//农历节日
this.solarFestival = ''//公历节日
this.solarTerms = ''//节气
}
//===== 某年的第n个节气为几日(从0小寒起算)
function sTerm(y,n) {
var offDate = new Date( ( 31556925974.7*(y-1900) + sTermInfo[n]*60000 ) + Date.UTC(1900,0,6,2,5) )
return(offDate.getUTCDate())
}
function strDate(objDate)
{
var tY = objDate.getFullYear()
var tM = objDate.getMonth()+1
var tD = objDate.getDate()
var tH = objDate.getHours()
var s
s=+tY+"年"+tM+"月"+tD+"日"+tH+"时"
return s
}
function GetTerm(objDate) {
var year=objDate.getFullYear()
var d
var i
for (i=1i<23i+=2) {
d=sTerm(year,i)
if (objDate<d) break
}
if (i==1) i=23
return i
}
function calendar(y,m) {
var sDObj, lDObj, lY, lM, lD=1, lL, lX=0, tmp1, tmp2, tmp3, BMjqFtvl
var cY, cM, cD//年柱,月柱,日柱
var lDPOS = new Array(3)
var n = 0
var firstLM = 0
sDObj = new Date(y,m,1,0,0,0,0) //当月一日日期
this.length = solarDays(y,m) //公历当月天数
this.firstWeek = sDObj.getDay() //公历当月1日星期几
if(m<2) cY=cyclical(y-1900+36-1)
else cY=cyclical(y-1900+36)
var term2=sTerm(y,2)//立春日期
var firstNode = sTerm(y,m*2) //返回当月「节」为几日开始
cM = cyclical((y-1900)*12+m+12)
var dayCyclical = Date.UTC(y,m,1,0,0,0,0)/86400000+25567+10
for(var i=0i<this.lengthi++) {
if(lD>lX) {
sDObj = new Date(y,m,i+1) //当月一日日期
lDObj = new Lunar(sDObj) //农历
lY = lDObj.year //农历年
lM = lDObj.month//农历月
lD = lDObj.day //农历日
lL = lDObj.isLeap//农历是否闰月
lX = lL? leapDays(lY): monthDays(lY,lM)//农历当月最后一天
if(n==0) firstLM = lM
lDPOS[n++] = i-lD+1
}
if(m==1 &&(i+1)==term2) cY=cyclical(y-1900+36)
if((i+1)==firstNode) cM = cyclical((y-1900)*12+m+13)
cD = cyclical(dayCyclical+i)
this[i] = new calElement(y, m+1, i+1, nStr1[(i+this.firstWeek)%7],
lY, lM, lD++, lL,
cY ,cM, cD )
}
sFtv = new Array(
"0101*新年元旦",
"0312 植树节 孙中山逝世纪念日",
"0314 国际警察日")
for(i in sFtv)
if(sFtv[i].match(/^(\d{2})(\d{2})([\s\*])(.+)$/))
if(Number(RegExp.$1)==(m+1)) {
this[Number(RegExp.$2)-1].solarFestival += RegExp.$4 + ' '
if(RegExp.$3=='*') this[Number(RegExp.$2)-1].color = 'red'
}
}
function cMonth(d){
var s
switch (d) {
case 1:s = '正'break
case 11: s = '冬'break
case 12: s = '腊'break
break
default :
s = nStr1[d%12]
}
return(s)
}
function cDay(d){
var s
switch (d) {
case 10: s = '初十'break
case 20: s = '二十'break
break
case 30: s = '三十'break
break
default :
s = nStr2[Math.floor(d/10)]
s += nStr1[d%10]
}
return(s)
}
var cld
function drawCld(years,months) {
var i,sD,s,size
cld = new calendar(years,months)
if(years>1874 &&years<1909) yDisplay = '光绪' + (((years-1874)==1)?'元':years-1874)
if(years>1908 &&years<1912) yDisplay = '宣统' + (((years-1908)==1)?'元':years-1908)
if(years>1911 &&years<1950) yDisplay = '民国' + (((years-1911)==1)?'元':years-1911)
if(years>1948) yDisplay = '建国<font color=red>' + (((years-1949)==1)?'元':years-1949)
GZ.innerHTML = yDisplay+'</font>年'+'</a> '+Animals[(years-4)%12]+'年[农历<font color=red>' + cyclical(years-1900+36)+'</font>年]'
for(i=0i<42i++) {
sObj=eval('SD'+ i)
lObj=eval('LD'+ i)
sObj.className = ''
sD = i - cld.firstWeek
if(sD>-1 &&sD<cld.length) { //日期内
sObj.innerHTML = sD+1
if(cld[sD].isToday) sObj.className = 'todyaColor'//今日颜色
if(cld[sD].lDay==1) //显示农历月
lObj.innerHTML = '<b>'+(cld[sD].isLeap?'闰':'') + cld[sD].lMonth + '月' + (monthDays(cld[sD].lYear,cld[sD].lMonth)==29?'小':'大')+'</b>'
else //显示农历日
lObj.innerHTML = cDay(cld[sD].lDay)
s=cld[sD].solarFestival
if(s.length>0) {//公历节日
size = (s.charCodeAt(0)>0 &&s.charCodeAt(0)<128)?8:4
if(s.length>size+2) s = s.substr(0, size)+'...'
s=(s=='黑色星期五')?s.fontcolor('black'):s.fontcolor('blue')
}
else {
s=cld[sD].lunarFestival
if(s.length>0) { //农历节日
if(s.length>6) s = s.substr(0, 4)+'...'
s = s.fontcolor('red')
}
else { //廿四节气
s=cld[sD].solarTerms
if(s.length>0) s = s.fontcolor('limegreen')
}
}
if(s.length>0) lObj.innerHTML = s
}
else { //非日期
sObj.innerHTML = ''
lObj.innerHTML = ''
}
}
}
function changeCld() {
var y,m
y=CLD.years.selectedIndex+1900
m=CLD.months.selectedIndex
drawCld(y,m)
}
var Today = new Date()
var tY = Today.getFullYear()
var tM = Today.getMonth()
var tD = Today.getDate()
var width = "130"
var offsetx = 2
var offsety = 8
var x = 0
var y = 0
var snow = 0
var sw = 0
var cnt = 0
var dStyle
document.onmousemove = mEvn
function mOvr(v) {
var s,festival,sjqFtvl
var sObj=eval('SD'+ v)
var d=sObj.innerHTML-1
if(sObj.innerHTML!='') {
sObj.style.cursor= 'help'
if(cld[d].solarTerms == '' &&cld[d].solarFestival == '' &&cld[d].lunarFestival == '')
festival = ''
else
festival = '<TABLE WIDTH=100% BORDER=0 CELLPADDING=2 CELLSPACING=0 BGCOLOR="#CCFFCC"><TR><TD ALIGN="center">'+
'<FONT COLOR="#000000" STYLE="font-size:9pt">'+cld[d].solarTerms + ' ' +'</FONT></TD>'+
'</TR></TABLE>'
s= '<table border="2" width="140" bordercolor="#0066CC" bgcolor="#FFFBE8" cellpadding="0" cellspacing="0"><TR><td>' +
'<TABLE WIDTH=100% BORDER=0 CELLPADDING=0 CELLSPACING=0><TR><TD ALIGN="center"><FONT COLOR="#ff00ff" STYLE="font-size:9pt">'+
cld[d].sYear+'年'+cld[d].sMonth+'月'+cld[d].sDay+'日 星期'+cld[d].week+'<br>'+
'<font color="#FF8000">农历'+cld[d].cYear+'年'+(cld[d].isLeap?' 闰':' ')+cMonth(cld[d].lMonth)+'月'+cDay(cld[d].lDay)+'</font><br>'+
'<font color="009900">'+cld[d].cYear+'年 '+cld[d].cMonth+'月 '+cld[d].cDay + '日</font>'+
'</FONT></TD></TR></TABLE>'+ festival +'</TD></TR></TABLE>'
document.all["detail"].innerHTML = s
if (snow == 0) {
dStyle.left = x+offsetx-(width/2)
dStyle.top = y+offsety
dStyle.visibility = "visible"
snow = 1
}
}
}
function mOut() {
if ( cnt >= 1 ) { sw = 0}
if ( sw == 0 ) { snow = 0dStyle.visibility = "hidden"}
else cnt++
}
function mEvn() {
x=event.x
y=event.y
if (document.body.scrollLeft)
{x=event.x+document.body.scrollLefty=event.y+document.body.scrollTop}
if (snow){
dStyle.left = x+offsetx-(width/2)
dStyle.top = y+offsety
}
}
function jieqi(objDate) {
var year=objDate.getFullYear()
var dvar ivar m
for (i=0i<24i+=1) {
d=sTerm(year,i)
m=i
if (objDate<=d) break
} return m
}
function mDown(V) {
var sObj=eval('SD'+ V)
var D=sObj.innerHTML-1
var ya=cld[D].sYear//获得当前公历日期!
var ma=cld[D].sMonth
var da=cld[D].sDay
var Today=new Date(ya,ma,da,0,0,0)
m=jieqi(Today)
document.all.s3.value=m
}
function setCookie(name,value) {
var today = new Date()
var expires = new Date()
expires.setTime(today.getTime() + 1000*60*60*24*365)
document.cookie = name + "=" + escape(value) + "expires=" + expires.toGMTString()
}
function getCookie(Name) {
var search = Name + "="
if(document.cookie.length >0) {
offset = document.cookie.indexOf(search)
if(offset != -1) {
offset += search.length
end = document.cookie.indexOf("", offset)
if(end == -1) end = document.cookie.length
return unescape(document.cookie.substring(offset, end))
}
else return('')
}
else return('')
}
function initialize() {
dStyle = detail.style
CLD.years.selectedIndex=tY-1900
CLD.months.selectedIndex=tM
drawCld(tY,tM)
}
</SCRIPT>
<STYLE>
.todyaColor {BACKGROUND-COLOR: aqua}
</STYLE><META content="MSHTML 6.00.2900.2802" name=GENERATOR></HEAD>
<BODY onload=initialize()>
<DIV id=detail
style="Z-INDEX: 3FILTER: shadow(color=#333333,direction=135)WIDTH: 140pxPOSITION: absoluteHEIGHT: 120px"></DIV>
<CENTER>
<TABLE border=0>
<TBODY>
<TR>
<FORM name=xz>
<TD width=440 align=center vAlign=top bgcolor="#CCCCCC">
<label>122
<textarea width=440 name="textarea"></textarea>
</label>
</FORM>
<FORM name=CLD>
<TD align=middle>
<TABLE width="300" border="0" cellSpacing=1 cellPadding=0>
<TR> <TBODY> <TR bgcolor="#319AFF">
<TD colSpan=7 align="center"><FONT style="FONT-SIZE: 9pt"
color=#9900CC size=3> 公元
<SELECT onchange=changeCld() name=years> <SCRIPT language=JavaScript> for(i=1900i<2101i++) document.write('<option>'+i)</SCRIPT> </SELECT>年
<SELECT onchange=changeCld() name=months> <SCRIPT language=JavaScript> for(i=1i<13i++) document.write('<option>'+i)</SCRIPT> </SELECT>月
第 <input name="s3" type="text" size="2" >个节气
<SELECT name=hours><SCRIPT language=JavaScript> for(i=1i<13i++) document.write('<option>'+i)</SCRIPT> </SELECT>时 </FONT> <TR align=middle bgColor=#FF9900>
<TD width=54><FONT color=red>日</FONT><FONT color="#e7f7fe">SUN</FONT></TD>
<TD width=54>一<FONT color="#e7f7fe">MON</FONT></TD>
<TD width=54>二<FONT color="#e7f7fe">TUE</FONT></TD>
<TD width=54>三<FONT color="#e7f7fe">WED</FONT></TD>
<TD width=54>四<FONT color="#e7f7fe">THR</FONT></TD>
<TD width=54>五<FONT color="#e7f7fe">FRI</FONT></TD>
<TD width=54><FONT color=green>六</FONT><FONT color="#e7f7fe">SAT</FONT></TD></TR>
<SCRIPT language=JavaScript><!--
var gNum
for(i=0i<6i++) {
document.write('<tr align=center>')
for(j=0j<7j++) {
gNum = i*7+j
document.write('<td id="GD' + gNum +'" onMouseOver="mOvr(' + gNum +')" onMouseOut="mOut()" onMouseDown="mDown(' + gNum +')"')
document.write('><font id="SD' + gNum +'" size=5 face="Arial Black"')
if(j == 0) document.write(' color=red')
if(j == 6)
if(i%2==1) document.write(' color=red')
else document.write(' color=green')
document.write(' TITLE=""></font><br><font id="LD' + gNum + '" size=2 style="font-size:9pt"></font></td>')
}
document.write('</tr>')
}
//--></SCRIPT>
</TBODY></TABLE></TD>
<TD width=60 align=middle vAlign=top bgcolor="#CCCCCC"><BR><BR><P><TR> <TD align=right bgColor=#00aa55 colSpan=8><FONT color=#fffff face=宋体 id=GZ></FONT></TD></TR></TBODY></TABLE></TD></FORM></CENTER></TR></TBODY></TABLE></CENTER></BODY></HTML>
<html><head>
<base fptype="TRUE">
<meta http-equiv="Content-Type" content="text/htmlcharset=gb2312">
<title>本地时间</title>
<script>setInterval("jnkc.innerHTML=new Date().toLocaleString()+' 星期'+'日一二三四五六'.charAt(new Date().getDay())",1000)</script>
<marquee scrollamount=8><div id='jnkc'></div>
</marquee>
</head>
<body>
<script language=javascript>
function settab()
{
var tab=document.getElementById('tab1')
//alert(se1.options[se1.selectedIndex].text)
var se11=se1.options[se1.selectedIndex].text
var se21=se2.options[se2.selectedIndex].text//下拉列表中的日期
//alert(se11+","+se21)
var lastday=new Date(se11,se21,0).getDate()//所选择月的天数
var firstday=new Date(se11,se21-1,1).getDay()//选择月的第一天是星期几
//alert(lastday+","+firstday)
var weekend//每周的最后一天的日期
var lines//第几行,相对于表格,星期为第零行
//第一行日期
for(var lin1=0lin1<7lin1++)
{
if(lin1<firstday)
tab.rows[1].cells[lin1].innerHTML=" "
else
if(lin1==0||lin1==6)
tab.rows[1].cells[lin1].innerHTML="<font color=red>"+(lin1-firstday+1)+"</font>"
else
tab.rows[1].cells[lin1].innerHTML=lin1-firstday+1
//alert(lin1+","+firstday)
weekend=lin1-firstday+1
lines=1//第一行
}
//将最后2行值空之后再添加数据,以免遗留上一个月的数据,二行相对于非闰年的二月份
for(var i=0i<7i++)
{
tab.rows[5].cells[i].innerHTML=" "
tab.rows[6].cells[i].innerHTML=" "
}
while(weekend<lastday)//循环到月末
{
for(var lin2=0lin2<7lin2++)
{
if(weekend+lin2<lastday)//数字小于等于当前月的最后一天
{
if(lin2==0||lin2==6)
tab.rows[lines+1].cells[lin2].innerHTML="<font color=red>"+(weekend+1+lin2)+"</font>"
else
tab.rows[lines+1].cells[lin2].innerHTML=weekend+1+lin2
}
<HTML><HEAD><TITLE>在线日历</TITLE><META
content="农历阳历月历节日时区节气八字干支生肖gregorian solarchinese lunarcalendar"
name=keywords>
<META content=All name=robots>
<META http-equiv=Content-Type content="text/htmlcharset=gb2312">
<STYLE>BODY {
FONT-SIZE: 9pt
}
TABLE {
FONT-SIZE: 9pt
}
</STYLE>
<SCRIPT language=JavaScript>
function click() {
if (event.button==2) {alert('欢迎访问农历与阳历对照陈年老黄历') }}
document.onmousedown=click
</SCRIPT>
<SCRIPT language=JavaScript>
<!--
/*****************************************************************************
日期资料
*****************************************************************************/
var lunarInfo=new Array(
0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,
0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,
0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,
0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,
0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,
0x06ca0,0x0b550,0x15355,0x04da0,0x0a5d0,0x14573,0x052d0,0x0a9a8,0x0e950,0x06aa0,
0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,
0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b5a0,0x195a6,
0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,
0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,
0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,
0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,
0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,
0x05aa0,0x076a3,0x096d0,0x04bd7,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,
0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0)
var solarMonth=new Array(31,28,31,30,31,30,31,31,30,31,30,31)
var Gan=new Array("甲","乙","丙","丁","戊","己","庚","辛","壬","癸")
var Zhi=new Array("子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥")
var Animals=new Array("鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪")
var solarTerm = new Array("小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至")
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)
var nStr1 = new Array('日','一','二','三','四','五','六','七','八','九','十')
var nStr2 = new Array('初','十','廿','卅',' ')
var monthName = new Array("1 月","2 月","3 月","4 月","5 月","6 月","7 月","8 月","9 月","10 月","11 月","12 月")
//国历节日 *表示放假日
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 毛泽东诞辰纪念")
//农历节日 *表示放假日
var lFtv = new Array(
"0101*春节",
"0115 元宵节",
"0505 端午节",
"0715 中元节",
"0815 中秋节",
"0909 重阳节",
"1208 腊八节",
"1224 小年",
"0100*除夕")
//某月的第几个星期几
var wFtv = new Array(
"0520 母亲节",
"0716 合作节",
"0730 被奴役国家周")
/*****************************************************************************
日期计算
*****************************************************************************/
//====================================== 传回农历 y年的总天数
function lYearDays(y) {
var i, sum = 348
for(i=0x8000i>0x8i>>=1) sum += (lunarInfo[y-1900] &i)? 1: 0
return(sum+leapDays(y))
}
//====================================== 传回农历 y年闰月的天数
function leapDays(y) {
if(leapMonth(y)) return((lunarInfo[y-1900] &0x10000)? 30: 29)
else return(0)
}
//====================================== 传回农历 y年闰哪个月 1-12 , 没闰传回 0
function leapMonth(y) {
return(lunarInfo[y-1900] &0xf)
}
//====================================== 传回农历 y年m月的总天数
function monthDays(y,m) {
return( (lunarInfo[y-1900] &(0x10000>>m))? 30: 29 )
}
//====================================== 算出农历, 传入日期物件, 传回农历日期物件
// 该物件属性有 .year .month .day .isLeap .yearCyl .dayCyl .monCyl
function Lunar(objDate) {
var i, leap=0, temp=0
var baseDate = new Date(1900,0,31)
var offset = (objDate - baseDate)/86400000
this.dayCyl = offset + 40
this.monCyl = 14
for(i=1900i<2050 &&offset>0i++) {
temp = lYearDays(i)
offset -= temp
this.monCyl += 12
}
if(offset<0) {
offset += temp
i--
this.monCyl -= 12
}
this.year = i
this.yearCyl = i-1864
leap = leapMonth(i) //闰哪个月
this.isLeap = false
for(i=1i<13 &&offset>0i++) {
//闰月
if(leap>0 &&i==(leap+1) &&this.isLeap==false)
{ --ithis.isLeap = truetemp = leapDays(this.year)}
else
{ temp = monthDays(this.year, i)}
//解除闰月
if(this.isLeap==true &&i==(leap+1)) this.isLeap = false
offset -= temp
if(this.isLeap == false) this.monCyl ++
}
if(offset==0 &&leap>0 &&i==leap+1)
if(this.isLeap)
{ this.isLeap = false}
else
{ this.isLeap = true--i--this.monCyl}
if(offset<0){ offset += temp--i--this.monCyl}
this.month = i
this.day = offset + 1
}
//==============================传回阳历 y年某m+1月的天数
function solarDays(y,m) {
if(m==1)
return(((y%4 == 0) &&(y%100 != 0) || (y%400 == 0))? 29: 28)
else
return(solarMonth[m])
}
//============================== 传入 offset 传回干支, 0=甲子
function cyclical(num) {
return(Gan[num%10]+Zhi[num%12])
}
//============================== 月历属性
function calElement(sYear,sMonth,sDay,week,lYear,lMonth,lDay,isLeap,cYear,cMonth,cDay) {
this.isToday= false
//阳历
this.sYear = sYear
this.sMonth = sMonth
this.sDay = sDay
this.week = week
//农历
this.lYear = lYear
this.lMonth = lMonth
this.lDay = lDay
this.isLeap = isLeap
//干支
this.cYear = cYear
this.cMonth = cMonth
this.cDay = cDay
this.color = ''
this.lunarFestival = ''//农历节日
this.solarFestival = ''//阳历节日
this.solarTerms= ''//节气
}
//===== 某年的第n个节气为几日(从0小寒起算)
function sTerm(y,n) {
var offDate = new Date( ( 31556925974.7*(y-1900) + sTermInfo[n]*60000 ) + Date.UTC(1900,0,6,2,5) )
return(offDate.getUTCDate())
}
//============================== 传回月历物件 (y年,m+1月)
function calendar(y,m) {
var sDObj, lDObj, lY, lM, lD=1, lL, lX=0, tmp1, tmp2
var lDPOS = new Array(3)
var n = 0
var firstLM = 0
sDObj = new Date(y,m,1)//当月一日日期
this.length= solarDays(y,m)//阳历当月天数
this.firstWeek = sDObj.getDay()//阳历当月1日星期几
for(var i=0i<this.lengthi++) {
if(lD>lX) {
sDObj = new Date(y,m,i+1)//当月一日日期
lDObj = new Lunar(sDObj) //农历
lY= lDObj.year //农历年
lM= lDObj.month //农历月
lD= lDObj.day//农历日
lL= lDObj.isLeap //农历是否闰月
lX= lL? leapDays(lY): monthDays(lY,lM) //农历当月最后一天
if(n==0) firstLM = lM
lDPOS[n++] = i-lD+1
}
//sYear,sMonth,sDay,week,
//lYear,lMonth,lDay,isLeap,
//cYear,cMonth,cDay
this[i] = new calElement(y, m+1, i+1, nStr1[(i+this.firstWeek)%7],
lY, lM, lD++, lL,
cyclical(lDObj.yearCyl) ,cyclical(lDObj.monCyl), cyclical(lDObj.dayCyl++) )
if((i+this.firstWeek)%7==0) this[i].color = 'red' //周日颜色
if((i+this.firstWeek)%14==13) this[i].color = 'red' //周休二日颜色
}
//节气
tmp1=sTerm(y,m*2 )-1
tmp2=sTerm(y,m*2+1)-1
this[tmp1].solarTerms = solarTerm[m*2]
this[tmp2].solarTerms = solarTerm[m*2+1]
if(m==3) this[tmp1].color = 'red' //清明颜色
//阳历节日
for(i in sFtv)
if(sFtv[i].match(/^(\d{2})(\d{2})([\s\*])(.+)$/))
if(Number(RegExp.$1)==(m+1)) {
this[Number(RegExp.$2)-1].solarFestival += RegExp.$4 + ' '
if(RegExp.$3=='*') this[Number(RegExp.$2)-1].color = 'red'
}
//月周节日
for(i in wFtv)
if(wFtv[i].match(/^(\d{2})(\d)(\d)([\s\*])(.+)$/))
if(Number(RegExp.$1)==(m+1)) {
tmp1=Number(RegExp.$2)
tmp2=Number(RegExp.$3)
this[((this.firstWeek>tmp2)?7:0) + 7*(tmp1-1) + tmp2 - this.firstWeek].solarFestival += RegExp.$5 + ' '
}
//农历节日
for(i in lFtv)
if(lFtv[i].match(/^(\d{2})(.{2})([\s\*])(.+)$/)) {
tmp1=Number(RegExp.$1)-firstLM
if(tmp1==-11) tmp1=1
if(tmp1 >=0 &&tmp1<n) {
tmp2 = lDPOS[tmp1] + Number(RegExp.$2) -1
if( tmp2 >= 0 &&tmp2<this.length) {
this[tmp2].lunarFestival += RegExp.$4 + ' '
if(RegExp.$3=='*') this[tmp2].color = 'red'
}
}
}
//黑色星期五
if((this.firstWeek+12)%7==5)
this[12].solarFestival += '黑色星期五 '
//今日
if(y==tY &&m==tM) this[tD-1].isToday = true
}
//====================== 中文日期
function cDay(d){
var s
switch (d) {
case 10:
s = '初十'break
case 20:
s = '二十'break
break
case 30:
s = '三十'break
break
default :
s = nStr2[Math.floor(d/10)]
s += nStr1[d%10]
}
return(s)
}
///////////////////////////////////////////////////////////////////////////////
var cld
function drawCld(SY,SM) {
var i,sD,s,size
cld = new calendar(SY,SM)
if(SY>1874 &&SY<1909) yDisplay = '光绪' + (((SY-1874)==1)?'元':SY-1874)
if(SY>1908 &&SY<1912) yDisplay = '宣统' + (((SY-1908)==1)?'元':SY-1908)
if(SY>1911 &&SY<1950) yDisplay = '民国' + (((SY-1911)==1)?'元':SY-1911)
if(SY>1949) yDisplay = '' + (((SY-1949)==1)?'元':SY)
GZ.innerHTML = yDisplay +'年 农历' + cyclical(SY-1900+36) + '年 【'+Animals[(SY-4)%12]+'】'
YMBG.innerHTML = " " + SY + "<BR> " + monthName[SM]
for(i=0i<42i++) {
sObj=eval('SD'+ i)
lObj=eval('LD'+ i)
sObj.className = ''
sD = i - cld.firstWeek
if(sD>-1 &&sD<cld.length) { //日期内
sObj.innerHTML = sD+1
if(cld[sD].isToday) sObj.className = 'todyaColor'//今日颜色
sObj.style.color = cld[sD].color//国定假日颜色
if(cld[sD].lDay==1) //显示农历月
lObj.innerHTML = '<b>'+(cld[sD].isLeap?'闰':'') + cld[sD].lMonth + '月' + (monthDays(cld[sD].lYear,cld[sD].lMonth)==29?'小':'大')+'</b>'
else //显示农历日
lObj.innerHTML = cDay(cld[sD].lDay)
s=cld[sD].lunarFestival
if(s.length>0) { //农历节日
if(s.length>6) s = s.substr(0, 4)+'…'
s = s.fontcolor('red')
}
else { //国历节日
s=cld[sD].solarFestival
if(s.length>0) {
size = (s.charCodeAt(0)>0 &&s.charCodeAt(0)<128)?8:4
if(s.length>size+2) s = s.substr(0, size)+'…'
s = s.fontcolor('blue')
}
else { //廿四节气
s=cld[sD].solarTerms
if(s.length>0) s = s.fontcolor('limegreen')
}
}
if(s.length>0) lObj.innerHTML = s
}
else { //非日期
sObj.innerHTML = ''
lObj.innerHTML = ''
}
}
}
function changeCld() {
var y,m
y=CLD.SY.selectedIndex+1900
m=CLD.SM.selectedIndex
drawCld(y,m)
}
function pushBtm(K) {
switch (K){
case 'YU' :
if(CLD.SY.selectedIndex>0) CLD.SY.selectedIndex--
break
case 'YD' :
if(CLD.SY.selectedIndex<149) CLD.SY.selectedIndex++
break
case 'MU' :
if(CLD.SM.selectedIndex>0) {
CLD.SM.selectedIndex--
}
else {
CLD.SM.selectedIndex=11
if(CLD.SY.selectedIndex>0) CLD.SY.selectedIndex--
}
break
case 'MD' :
if(CLD.SM.selectedIndex<11) {
CLD.SM.selectedIndex++
}
else {
CLD.SM.selectedIndex=0
if(CLD.SY.selectedIndex<149) CLD.SY.selectedIndex++
}
break
default :
CLD.SY.selectedIndex=tY-1900
CLD.SM.selectedIndex=tM
}
changeCld()
}
var Today = new Date()
var tY = Today.getFullYear()
var tM = Today.getMonth()
var tD = Today.getDate()
//////////////////////////////////////////////////////////////////////////////
var width = "130"
var offsetx = 2
var offsety = 16
var x = 0
var y = 0
var snow = 0
var sw = 0
var cnt = 0
var dStyle
document.onmousemove = mEvn
//显示详细日期资料
function mOvr(v) {
var s,festival
var sObj=eval('SD'+ v)
var d=sObj.innerHTML-1
//sYear,sMonth,sDay,week,
//lYear,lMonth,lDay,isLeap,
//cYear,cMonth,cDay
if(sObj.innerHTML!='') {
sObj.style.cursor = 's-resize'
if(cld[d].solarTerms == '' &&cld[d].solarFestival == '' &&cld[d].lunarFestival == '')
festival = ''
else
festival = '<TABLE WIDTH=100% BORDER=0 CELLPADDING=2 CELLSPACING=0 BGCOLOR="#CCFFCC"><TR><TD>'+
'<FONT COLOR="#000000" STYLE="font-size:9pt">'+cld[d].solarTerms + ' ' + cld[d].solarFestival + ' ' + cld[d].lunarFestival+'</FONT></TD>'+
'</TR></TABLE>'
s= '<TABLE WIDTH="130" BORDER=0 CELLPADDING="2" CELLSPACING=0 BGCOLOR="#000066"><TR><TD>' +
'<TABLE WIDTH=100% BORDER=0 CELLPADDING=0 CELLSPACING=0><TR><TD ALIGN="right"><FONT COLOR="#ffffff" STYLE="font-size:9pt">'+
cld[d].sYear+' 年 '+cld[d].sMonth+' 月 '+cld[d].sDay+' 日<br>星期'+cld[d].week+'<br>'+
'<font color="violet">农历'+(cld[d].isLeap?'闰 ':' ')+cld[d].lMonth+' 月 '+cld[d].lDay+' 日</font><br>'+
'<font color="yellow">'+cld[d].cYear+'年 '+cld[d].cMonth+'月 '+cld[d].cDay + '日</font>'+
'</FONT></TD></TR></TABLE>'+ festival +'</TD></TR></TABLE>'
document.all["detail"].innerHTML = s
if (snow == 0) {
dStyle.left = x+offsetx-(width/2)
dStyle.top = y+offsety
dStyle.visibility = "visible"
snow = 1
}
}
}
//清除详细日期资料
function mOut() {
if ( cnt >= 1 ) { sw = 0 }
if ( sw == 0 ) { snow = 0dStyle.visibility = "hidden"}
else cnt++
}
//取得位置
function mEvn() {
x=event.x
y=event.y
if (document.body.scrollLeft)
{x=event.x+document.body.scrollLefty=event.y+document.body.scrollTop}
if (snow){
dStyle.left = x+offsetx-(width/2)
dStyle.top = y+offsety
}
}
///////////////////////////////////////////////////////////////////////////
function changeTZ() {
CITY.innerHTML = CLD.TZ.value.substr(6)
setCookie("TZ",CLD.TZ.selectedIndex)
}
function tick() {
var today
today = new Date()
Clock.innerHTML = today.toLocaleString().replace(/(年|月)/g, "/").replace(/日/, "")
Clock.innerHTML = TimeAdd(today.toGMTString(), CLD.TZ.value)
window.setTimeout("tick()", 1000)
}
function setCookie(name, value) {
var today = new Date()
var expires = new Date()
expires.setTime(today.getTime() + 1000*60*60*24*365)
document.cookie = name + "=" + escape(value) + "expires=" + expires.toGMTString()
}
function getCookie(Name) {
var search = Name + "="
if(document.cookie.length >0) {
offset = document.cookie.indexOf(search)
if(offset != -1) {
offset += search.length
end = document.cookie.indexOf("", offset)
if(end == -1) end = document.cookie.length
return unescape(document.cookie.substring(offset, end))
}
else return ""
}
}
/////////////////////////////////////////////////////////
function initial() {
dStyle = detail.style
CLD.SY.selectedIndex=tY-1900
CLD.SM.selectedIndex=tM
drawCld(tY,tM)
CLD.TZ.selectedIndex=getCookie("TZ")
changeTZ()
tick()
}
//-->
</SCRIPT>
<SCRIPT language=VBScript>
<!--
'===== 算世界时间
Function TimeAdd(UTC,T)
Dim PlusMinus, DST, y
If Left(T,1)="-" Then PlusMinus = -1 Else PlusMinus = 1
UTC=Right(UTC,Len(UTC)-5)
UTC=Left(UTC,Len(UTC)-4)
y = Year(UTC)
TimeAdd=DateAdd("n", (Cint(Mid(T,2,2))*60 + Cint(Mid(T,4,2))) * PlusMinus, UTC)
'美国日光节约期间: 4月第一个星期日00:00 至 10月最后一个星期日00:00
If Mid(T,6,1)="*" And DateSerial(y,4,(9 - Weekday(DateSerial(y,4,1)) mod 7) ) <= TimeAdd And DateSerial(y,10,31 - Weekday(DateSerial(y,10,31))) >= TimeAdd Then
TimeAdd=CStr(DateAdd("h", 1, TimeAdd))
tSave.innerHTML = "R"
Else
tSave.innerHTML = ""
End If
TimeAdd = CStr(TimeAdd)
End Function
'-->
</SCRIPT>
<STYLE>.todyaColor {
BACKGROUND-COLOR: aqua
}
</STYLE>
<META content="Microsoft FrontPage 4.0" name=GENERATOR></HEAD>
<BODY bgColor=#ffffff leftMargin=0 topMargin=0 onload=initial()>
<TABLE height=6 cellSpacing=0 cellPadding=0 width=400 align=center border=0>
<TBODY></TBODY></TABLE>
<SCRIPT language=JavaScript><!--
if(navigator.appName == "Netscape" || parseInt(navigator.appVersion) <4)
document.write("<h1>你的浏览器无法执行此程序。</h1>此程序在 IE4 以后的版本才能执行!!")
//--></SCRIPT>
<DIV id=detail style="POSITION: absolute"></DIV>
<CENTER>
<FORM name=CLD>
<TABLE>
<TBODY>
<TR>
<BR><BR>
<TD vAlign=top align=middle><FONT color=#008888 size=2>
<SCRIPT language=JavaScript>
var enabled = 0today = new Date()
var dayvar date
if(today.getDay()==0) day = "星期日"
if(today.getDay()==1) day = "星期一"
if(today.getDay()==2) day = "星期二"
if(today.getDay()==3) day = "星期三"
if(today.getDay()==4) day = "星期四"
if(today.getDay()==5) day = "星期五"
if(today.getDay()==6) day = "星期六"
document.fgColor = "000000"
</SCRIPT>
</FONT><BR><BR><FONT style="FONT-SIZE: 9pt" size=2>当地时间:</FONT><BR><FONT
id=Clock face=Arial color=#660080 size=4 align="center"></FONT>
<P><!--时区 *表示自动调整为日光节约时间--><FONT style="FONT-SIZE: 9pt" size=2><SELECT
style="FONT-SIZE: 9pt" onchange=changeTZ() name=TZ><OPTION
value="+0800 北京、重庆、黑龙江" selected>中国<OPTION value="+0800 台湾、香港、新加坡">台北<OPTION
value="-1200 安尼威土克、瓜甲兰" >国际换日线<OPTION
value="-1100 中途岛、萨摩亚群岛">萨摩亚<OPTION value="-1000 夏威夷">夏威夷<OPTION
value=-0900*阿拉斯加>阿拉斯加<OPTION value=-0800*太平洋时间(美加)、提亚纳>太平洋<OPTION
value="-0700 亚历桑那">美国山区<OPTION value=-0700*山区时间(美加)>美加山区<OPTION
value=-0600*萨克其万(加拿大)>加拿大中部<OPTION value=-0600*墨西哥市、塔克西卡帕>墨西哥<OPTION
value=-0600*中部时间(美加)>美加中部<OPTION value=-0500*波哥大