万年历使用总结

    最近从网上下载了一个万年历的小js脚本,学习了,有点小收获。

1、月份是从0开始的
2、initial中利用今天的年和月开始调用drawCld(tY,tM);(这里有1900,如果需要更改选项需要改这里)
3、drawCld这个函数比较复杂,需要好好研究研究。
1)cld = new calendar(SY,SM);产生日历对象。国历当月天数是需要的。


//农历数据信息 第一个数闰月的天数标志位(0表示29天,1表示30天),2,3,4表示对应的月份的天数(0,29天,1,30天),最后一位闰月的月份数(0,没有,其余则是对应的月份)
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)


//按周计算 月周日(日用0表示)
var wFtv = new Array(
"0520 国际母亲节",
"0530 全国助残日",
"0630 国际父亲节",
"0932 国际和平日",
"0940 国际聋人节",
"1013 国际减轻自然灾害日",
"1011 国际住房日"
);


需要改1900的三处,改了这三处,选择项也可以改,农历1900年1月的表示有问题,所以可以去掉,只能到2049年

第一处:function changeCld() {
var y,m;
y = document.getElementById("sy").selectedIndex + 1901;
m = document.getElementById("sm").selectedIndex;
      drawCld(y,m);
}

第二处:default :
document.getElementById("sy").selectedIndex = tY - 1901;
document.getElementById("sm").selectedIndex = tM;

第三处://界面初始化
function initial() {
//select

dStyle = document.getElementById("detail").style;
//fillSelect();
//fillCalendar();


document.getElementById("sy").selectedIndex=tY-1901;
document.getElementById("sm").selectedIndex=tM;
log(1,  "initial call drawCld() now");
drawCld(tY,tM);
     
//document.getElementById("tz").selectedIndex=getCookie("TZ");
//if(document.getElementById("tz").selectedIndex<1)
// document.getElementById("tz").selectedIndex=39;
//changeTZ();
//tick();

}


其实网上有大量源码,在这里我就粘过来了

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>兼容火狐、谷歌等主流浏览器的万年历</title>
<meta name="keywords" content="兼容火狐、谷歌,万年历,农历,阳历,月历,节日,时区,节气,八字,干支,实用查询,兼容IE/Firefox/Safari等浏览器">
<meta name="description" content="能够兼容火狐、谷歌等主流浏览器的万年历。">
<style>
.aorange {
font-size: 20px;
color: #ff5f07;
font-family: "黑体",serif;
font-weight: bold;
}
.agreen {
font-size: 20px;
color: #55e8df;
font-weight: bold;
}


.one {
font-family: "黑体",serif;
font-size: 20px;
color: #000;
font-weight: normal;
}


.spc {
color:#ff5f07;
}


div,select,p {
font-size: 12px;
color:#000;
 
}


div#festival {
color: #d8f6f8; 
width: 130px; 
padding: 2px; 
margin: 0; 
background-color: #0978a6; 
}
div#datedetail {
width: 130px; 
border: 0; 
padding: 2px; 
margin: 0; 
background-color:#e8f5f9; 
text-align:right; 
}
div#datedetail span {
color: #23460f;
}
div#detail {
position: absolute;
visibility: hidden;
margin: 0;
border:1px solid #a6a8ab;
}


div#date {
width:98%;
font-size:16px;
padding:5px;
border: 1px solid #a6a8ab; 
background-color: #e6f0fa;
}
div#calendar {
float:left;
text-align:center;
width:500px;
border: 1px solid #a6a8ab; 
border-top:0;
height:auto;
}
#calendarhead {
color: #fafbfb;
border:0;
padding:0;
margin:0;
background-color: #0978a6;
}


#calendarhead tr td {
width:70px;
font-weight:bold;
font-family:"黑体",serif;
font-size:20px;
padding:1px;
}


div#panel {
margin:0;
padding:10px;
}
div#panel div {
padding:2px;
margin-top:20px;
background:#e8f5f9;
border:1px solid #a6a8ab;
font-size:9pt;
cursor:pointer;
}


#week {
background-color: #fcfcfc;
border:0;
padding:0;
margin:0;
}
#week tr td {
padding:1px;
margin:0;
width:70px;
border-bottom: 1px solid #efefef;
border-left: 1px solid #efefef;
}


.tr2 td {
background-color: #e8f5f9;
}


#valid {
float:left;
margin:0;
padding: 30px;
}
#valid div {
padding:2px;
margin-top:20px;
}
#valid a img {
border:0;
}
</style>


<script type="text/javascript">
var debug = 2; // -1: disable; 0: all; N: show level N debug msg.


//农历数据信息 第一个数闰月的天数标志位(0表示29天,1表示30天),2,3,4表示对应的月份的天数(0,29天,1,30天),最后一位闰月的月份数(0,没有,其余则是对应的月份)
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("JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC");


//国历节日 *表示节假日
var sFtv = new Array(
"0101*元旦",
"0214 情人节",
"0308 妇女节",
"0312 植树节",
"0315 消费者权益日",
"0321 世界森林日、世界儿歌日",
"0322 世界水日",
"0323 世界气象日",
"0324 世界防治结核病日",

"0401 愚人节",
"0407 世界卫生日",
"0422 世界地球日",

"0501*劳动节",
"0504 青年节",
"0505 碘缺乏病防治日",
"0508 世界红十字日",
"0512 国际护士节",
"0515 国际家庭日",
"0517 世界电信日",
"0518 国际博物馆日",
"0520 全国学生营养日",
"0523 国际牛奶日",
"0531 世界无烟日",

"0601 儿童节",
"0605 世界环境日",
"0606 全国爱眼日",
"0616 防治荒漠化和干旱日",
"0623 国际奥林匹克日",
"0625 全国土地日",
"0626 国际反毒品日",

"0701 建党节 香港回归纪念 国际建筑日",
"0707 中国人民抗日战争纪念日",
"0711 世界人口日",

"0801 建军节",
"0808 父亲节",

"0908 国际扫盲日",
"0909 毛泽东逝世纪念",
"0910 教师节",
"0912 嘻嘻日",
"0916 国际臭氧层保护日",
"0920 国际爱牙日",
"0927 世界旅游日",
"0928 孔子诞辰",

"1001*国庆节 国际音乐日",
"1004 世界动物日",
"1006 老人节",
"1008 全国高血压日 世界视觉日",
"1009 世界邮政日",
"1015 国际盲人节",
"1016 世界粮食日",
"1017 世界消除贫困日",
"1024 联合国日",

"1108 中国记者日",
"1109 消防宣传日",
"1112 孙中山诞辰纪念",
"1114 世界糖尿病日",
"1117 国际大学生节",


"1201 世界艾滋病日",
"1203 世界残疾人日",
"1209 世界足球日",
"1220 澳门回归纪念",
"1225 圣诞节",
"1226 毛泽东诞辰纪念",
"1229 国际生物多样性日"
);


//农历节日 *表示节假日
var lFtv = new Array(
"0101*春节",
"0115 元宵节",
"0505 端午节",
"0707 七夕情人节",
"0715 中元节",
"0815 中秋节",
"0909 重阳节",
"1208 腊八节",
"1223 小年",
"0100*除夕"
);


//按周计算 月周日(日用0表示)
var wFtv = new Array(
"0520 国际母亲节",
"0530 全国助残日",
"0630 国际父亲节",
"0932 国际和平日",
"0940 国际聋人节",
"1013 国际减轻自然灾害日",
"1011 国际住房日"
);


function log(level,  msg) {
        if (debug == 0 || debug == level)
        if(window.console) {
                window.console.log("[DEBUG]" + msg);
        }
}


/*****************************************************************************
日期计算
*****************************************************************************/


var Today = new Date();
var tY = Today.getFullYear();
var tM = Today.getMonth();
var tD = Today.getDate();


var width = "130"; //detail层宽度
var offsetx = 2;
var offsety = 16;


var x = 0;
var y = 0;
var show = 0;
var sw = 0;
var cnt = 0;


var dStyle;
document.onmousemove = mEvn;


//====================================== 传回农历 y年的总天数
function lYearDays(y) {
   var i, sum = 348;
   for(i=0x8000; i>0x8; i>>=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 m = ""; // msg for log
   var i, leap=0, temp=0;
   var baseDate = new Date(1900,0,31);
// changed by hmisty 2005/07/23
//   var offset   = (objDate - baseDate)/86400000;
   var offset   = Math.floor((objDate.getTime() + 2206425600000)/86400000);
   //var offset   = Math.floor((objDate.getTime() + 2209017600000)/86400000);
   m += "objDate="+objDate.getTime()+", new Date(1900,0,31)="+baseDate.getTime();
   m += "offset="+offset;   
   this.dayCyl = offset + 40;
   this.monCyl = 14;


   for(i=1900; i<2050 && offset>0; i++) {
      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=1; i<13 && offset>0; i++) {//闰月
      if(leap>0 && i==(leap+1) && this.isLeap==false)
         { --i; this.isLeap = true; temp = 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;  
   m += "\noffset="+offset+", year="+this.year+", yearCyl="+this.yearCyl+", month="+this.month+",\n monthCyl="+this.monCyl+", day="+this.day+", dayCyl="+this.dayCyl+", leap="+leap;
   log(2, m);
}


//==============================传回国历 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) {
   log(1,  "y="+y+" n="+n+" sTermInfo[n]="+sTermInfo[n]+" Date.UTC(1900,0,6,2,5)="+Date.UTC(1900,0,6,2,5)+" Date.UTC(1970,0,1,0,0)="+Date.UTC(1970,0,1,0,0) );
// changed by hmisty 2005/07/23
//   var offDate = new Date( ( 31556925974.7*(y-1900) + sTermInfo[n]*60000  ) + Date.UTC(1900,0,6,2,5) );
   var offDate = new Date( ( 31556925974.7*(y-1900) + sTermInfo[n]*60000  ) -2208549300000 );
   // Negative epoch (time_t) values are not officially supported by the
   // POSIX standards.  On some systems, they are known not to work.
   // -- perldoc Time::Local


   return(offDate.getUTCDate());
}


//============================== 传回月历物件 (y年,m+1月)
function calendar(y,m) {
        log(1,  "i am in calendar() now");
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日星期几


        log(1,  "this.length: "+this.length);
        log(1,  "begin loop for(var i=0;i<this.length;i++)");
for(var i=0;i<this.length;i++) {
 
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;
  }
 
      //log(1,  "lDObj.dayCyl: "+lDObj.dayCyl);
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 = '#ff5f07';//周日颜色
if((i+this.firstWeek)%14==13) this[i].color = '#ff5f07';//周休二日颜色
      }
        log(1,  "end loop for(var i=0;i<this.length;i++)");
//节气
tmp1=sTerm(y,m*2  )-1;
tmp2=sTerm(y,m*2+1)-1;
log(1,  "m: "+m+" tmp1: "+tmp1+" "+solarTerm[m*2]+" tmp2: "+tmp2+" "+solarTerm[m*2+1]);
this[tmp1].solarTerms = solarTerm[m*2];
      this[tmp2].solarTerms = solarTerm[m*2+1];
if(m==3) this[tmp1].color = '#ff5f07';
        
        log(1,  "begin loop for(i in sFtv)");
//国历节日
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 = '#ff5f07';
      }
     
        log(1,  "begin loop for(i in wFtv)");
//月周节日
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 + ' ';
      }
     
        log(1,  "begin loop for(i in lFtv)");
//农历节日
for(i in lFtv)  
if(lFtv[i].match(/^(\d{2})(.{2})([\s\*])(.+)$/)) {
                        log(1,  lFtv[i]);
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) {
                                        log(1,  "tmp2 >= 0 && tmp2("+tmp2+")<this.length("+this.length+")");
                                        log(1,  RegExp.$4);
                                        log(1,  this[tmp2].lunarFestival);
this[tmp2].lunarFestival += RegExp.$4 + ' ';
                                        log(1,  RegExp.$3);
if(RegExp.$3=='*') this[tmp2].color = '#ff5f07';
}
}
  }
     
        log(1,  "begin 黑色星期五");
//黑色星期五
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;
case 30:
s = '三十';
break;
default :
s = nStr2[Math.floor(d/10)];
s += nStr1[d%10];
}
return(s);
}


var cld;


function drawCld(SY,SM) {
        log(1,  "i am in drawCld() now");
        
var i,sD,s,size;
log(1,  "begin to create calendar cld");
cld = new calendar(SY,SM);
        log(1,  "calendar cld creation finished");
/*
  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-1949)
*/
     
document.getElementById("gz").innerHTML = '  农历' 
+ cyclical(SY-1900+36) + '年   【'+Animals[(SY-4)%12]+'】';
        log(1,  "innerHTML of gz is "+document.getElementById("gz").innerHTML);
   //YMBG.innerHTML = " " + SY + "<BR> " + monthName[SM];
        
for(i=0;i<42;i++) {
 
sObj = document.getElementById('sd'+ i);
lObj = document.getElementById('ld'+ i);
 
sObj.style.background = '';
  lObj.style.background = '';
 
sD = i - cld.firstWeek;
 
if(sD>-1 && sD<cld.length) { //日期内      
sObj.innerHTML = sD+1;
if(cld[sD].isToday){
//设置今天的背景色
sObj.style.background = 'red';
//lObj.style.background = 'red';
}
      
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) {
//农历节日名称大于5个字截去
//if(s.length>5) s = s.substr(0, 3)+'…';
if(s.length>7) s = s.substr(0, 5)+'…';
s = s.fontcolor('#ff5f07');
}
else {//国历节日
s=cld[sD].solarFestival;
if(s.length>0) {
//阳历节日名称截去
//size = (s.charCodeAt(0)>0 && s.charCodeAt(0)<128)?8:4;
size = (s.charCodeAt(0)>0 && s.charCodeAt(0)<128)?9:5;
if(s.length>size+1) s = s.substr(0, size-1)+'…';
s = s.fontcolor('#0168ea');
}
else { //廿四节气
s=cld[sD].solarTerms;
if(s.length>0) s = s.fontcolor('#44d7cf');
}
}
if(s.length>0) lObj.innerHTML = s;
 
}
else {//非日期
sObj.innerHTML = ' ';
lObj.innerHTML = ' ';
}
      }
}




function changeCld() {
var y,m;
y = document.getElementById("sy").selectedIndex + 1901;
m = document.getElementById("sm").selectedIndex;
      drawCld(y,m);
}


function pushBtm(K) {
switch (K){
case 'YU' :
if(document.getElementById("sy").selectedIndex > 0)
      document.getElementById("sy").selectedIndex--;
break;
case 'YD' :
if(document.getElementById("sy").selectedIndex < 149) 
document.getElementById("sy").selectedIndex++;
      break;
case 'MU' :
if(document.getElementById("sm").selectedIndex > 0) {      
document.getElementById("sm").selectedIndex--;
}
else {
document.getElementById("sm").selectedIndex = 11;
if(document.getElementById("sy").selectedIndex > 0) 
document.getElementById("sy").selectedIndex--;
}
break;
case 'MD' :
if(document.getElementById("sm").selectedIndex < 11) {
document.getElementById("sm").selectedIndex++;
}
else {
document.getElementById("sm").selectedIndex = 0;
if(document.getElementById("sy").selectedIndex < 149) 
document.getElementById("sy").selectedIndex++;
}
break;
default :
document.getElementById("sy").selectedIndex = tY - 1901;
document.getElementById("sm").selectedIndex = tM;
}
changeCld();
}


//用detail层显示详细信息日期资料
function mOvr(v) {


var festival = document.getElementById("festival");
var datedetail = document.getElementById("datedetail");


var sObj = document.getElementById('sd'+ v);
//alert(v);
var d = sObj.innerHTML - 1;
     
if( sObj.innerHTML != '' ) {
sObj.style.cursor = 'move';
if(cld[d].solarTerms == '' 
&& cld[d].solarFestival == '' 
&& cld[d].lunarFestival == '')
{
festival.innerHTML = "";
festival.style.display = "none";
}
else
{

festival.innerHTML = cld[d].solarTerms + ' ' + cld[d].solarFestival + ' ' + cld[d].lunarFestival;
festival.style.display = "block";
}
datedetail.innerHTML = cld[d].sYear +' 年 '+ cld[d].sMonth
+ ' 月 '+cld[d].sDay +' 日<br />星期' + cld[d].week + '<br />'
+ '<span>农历' + (cld[d].isLeap?'闰 ':' ')
+ cld[d].lMonth + ' 月 ' + cld[d].lDay + ' 日<br />'
+ cld[d].cYear + '年 ' + cld[d].cMonth
+ '月 ' + cld[d].cDay + '日</span>';


if (show == 0) {
dStyle.left = (x + offsetx - (width/2)) + "px";
dStyle.top = (y + offsety) + "px";
    dStyle.visibility = "visible";
    show = 1;
}
}
}


//清除详细日期资料
function mOut() {
if ( cnt >= 1 ) { sw = 0 }
if ( sw == 0 ) { show = 0; dStyle.visibility = "hidden";}
else cnt++;
}


//获取鼠标坐标
function mEvn(e) {
if (!show) return;
if(window.event){
x = event.x ;
y = event.y ;
if (document.body.scrollLeft){
x += document.body.scrollLeft; 
y += document.body.scrollTop;
} 
// changed by hmisty 2005/07/23
      dStyle.left = (x + offsetx-(width/2)) + "px";
      dStyle.top = (y + offsety) + "px";
}
else {
      dStyle.left = (e.pageX + offsetx-(width/2)) + "px";
      dStyle.top = (e.pageY + offsety) + "px";
}
}


function changeTZ() {
   document.getElementById("city").innerHTML = document.getElementById("tz").value.substr(6);
   setCookie("TZ",document.getElementById("tz").selectedIndex);
}


function tick() {
var today;
today = new Date();
document.getElementById("clock").innerHTML = today.getFullYear() + "年"
+ today.getMonth() + "月" + today.getDay() + "日" + today.getTime();
/*
  document.getElementById("clock").innerHTML = today.toLocaleString().replace(/(年|月)/g, "/").replace(/日/, ""); 
  document.getElementById("clock").innerHTML = TimeAdd(today.toGMTString(), document.getElementById("tz").value);
*/
//alert(document.getElementById("clock").innerHTML);
      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 fillSelect() {
syd = document.getElementById("sy");
syd.innerHTML = "";
for(i=1900;i<2050;i++)
{
ins = document.createElement("OPTION");
ins.innerHTML = i;
syd.appendChild(ins);
}
smd = document.getElementById("sm");
smd.innerHTML = "";
for(i=1;i<13;i++)
{
ins = document.createElement("OPTION");
ins.innerHTML = i;
smd.appendChild(ins);
}
}
//新增
function fillCalendar() {
var gNum;
var tablex = document.createElement("table");
tablex.setAttribute("id","week");
for(i=0;i<6;i++) {
var trx1 = document.createElement("tr");
var trx2 = document.createElement("tr");
trx1.setAttribute("class","tr1");
trx2.setAttribute("class","tr2");
for(j=0;j<7;j++) {
gNum = i*7+j;
var tdx = document.createElement("td");
tdx.setAttribute("id","sd"+gNum);
tdx.setAttribute("onMouseOver",'mOvr('+gNum+')');
tdx.setAttribute("onMouseOut","mOut()");
if(j == 0){
tdx.setAttribute("class","aorange");
}
else if(j == 6){
if(i%2==1) tdx.setAttribute("class","aorange");
else tdx.setAttribute("class","agreen");
}
else{
tdx.setAttribute("class","one");
}
trx1.appendChild(tdx);

tdx = document.createElement("td");
tdx.setAttribute("id","ld"+gNum);
tdx.setAttribute("onMouseOver",'mOvr('+gNum+')');
tdx.setAttribute("onMouseOut","mOut()");
trx2.appendChild(tdx);
}
tablex.appendChild(trx1);
tablex.appendChild(trx2);
}
document.getElementById("calendar").appendChild(tablex);
}
//界面初始化
function initial() {
//select

dStyle = document.getElementById("detail").style;
//fillSelect();
//fillCalendar();


document.getElementById("sy").selectedIndex=tY-1901;
document.getElementById("sm").selectedIndex=tM;
log(1,  "initial call drawCld() now");
drawCld(tY,tM);
     
//document.getElementById("tz").selectedIndex=getCookie("TZ");
//if(document.getElementById("tz").selectedIndex<1)
// document.getElementById("tz").selectedIndex=39;
//changeTZ();
//tick();




}


function TimeAdd(UTC,T)
{
var PlusMinus, DST, y;
//alert(T);
alert(UTC);
if (T.substr(0,1) == "-"){
PlusMinus = -1;
}
else{
PlusMinus = 1;
}
//UTC = UTC.substr(1
}


</script>
</head>
<body οnlοad="initial()">


<table width="100%" border="0" cellspacing="0" cellpadding="0" style="background-color:#FFFFFF; margin:auto;">
  <tr>
    <td>
<table width="600" cellpadding="0" cellspacing="0" style="border:1px solid #666;" align="center">
  <tr>
    <td colspan="2" valign="top">
<div id="date" style="text-align:center;">
      <p>公历
        <select name="select" id="sy" οnchange="changeCld()">
            <option>1901</option>
            <option>1902</option>
            <option>1903</option>
            <option>1904</option>
            <option>1905</option>
            <option>1906</option>
            <option>1907</option>
            <option>1908</option>
            <option>1909</option>
            <option>1910</option>
            <option>1911</option>
            <option>1912</option>
            <option>1913</option>
            <option>1914</option>
            <option>1915</option>
            <option>1916</option>
            <option>1917</option>
            <option>1918</option>
            <option>1919</option>
            <option>1920</option>
            <option>1921</option>
            <option>1922</option>
            <option>1923</option>
            <option>1924</option>
            <option>1925</option>
            <option>1926</option>
            <option>1927</option>
            <option>1928</option>
            <option>1929</option>
            <option>1930</option>
            <option>1931</option>
            <option>1932</option>
            <option>1933</option>
            <option>1934</option>
            <option>1935</option>
            <option>1936</option>
            <option>1937</option>
            <option>1938</option>
            <option>1939</option>
            <option>1940</option>
            <option>1941</option>
            <option>1942</option>
            <option>1943</option>
            <option>1944</option>
            <option>1945</option>
            <option>1946</option>
            <option>1947</option>
            <option>1948</option>
            <option>1949</option>
            <option>1950</option>
            <option>1951</option>
            <option>1952</option>
            <option>1953</option>
            <option>1954</option>
            <option>1955</option>
            <option>1956</option>
            <option>1957</option>
            <option>1958</option>
            <option>1959</option>
            <option>1960</option>
            <option>1961</option>
            <option>1962</option>
            <option>1963</option>
            <option>1964</option>
            <option>1965</option>
            <option>1966</option>
            <option>1967</option>
            <option>1968</option>
            <option>1969</option>
            <option>1970</option>
            <option>1971</option>
            <option>1972</option>
            <option>1973</option>
            <option>1974</option>
            <option>1975</option>
            <option>1976</option>
            <option>1977</option>
            <option>1978</option>
            <option>1979</option>
            <option>1980</option>
            <option>1981</option>
            <option>1982</option>
            <option>1983</option>
            <option>1984</option>
            <option>1985</option>
            <option>1986</option>
            <option>1987</option>
            <option>1988</option>
            <option>1989</option>
            <option>1990</option>
            <option>1991</option>
            <option>1992</option>
            <option>1993</option>
            <option>1994</option>
            <option>1995</option>
            <option>1996</option>
            <option>1997</option>
            <option>1998</option>
            <option>1999</option>
            <option>2000</option>
            <option>2001</option>
            <option>2002</option>
            <option>2003</option>
            <option>2004</option>
            <option>2005</option>
            <option>2006</option>
            <option>2007</option>
            <option>2008</option>
            <option>2009</option>
            <option>2010</option>
            <option>2011</option>
            <option>2012</option>
            <option>2013</option>
            <option>2014</option>
            <option>2015</option>
            <option>2016</option>
            <option>2017</option>
            <option>2018</option>
            <option>2019</option>
            <option>2020</option>
            <option>2021</option>
            <option>2022</option>
            <option>2023</option>
            <option>2024</option>
            <option>2025</option>
            <option>2026</option>
            <option>2027</option>
            <option>2028</option>
            <option>2029</option>
            <option>2030</option>
            <option>2031</option>
            <option>2032</option>
            <option>2033</option>
            <option>2034</option>
            <option>2035</option>
            <option>2036</option>
            <option>2037</option>
            <option>2038</option>
            <option>2039</option>
            <option>2040</option>
            <option>2041</option>
            <option>2042</option>
            <option>2043</option>
            <option>2044</option>
            <option>2045</option>
            <option>2046</option>
            <option>2047</option>
            <option>2048</option>
            <option>2049</option>
        </select>
        年
        <select name="select2" id="sm" οnchange="changeCld()">
          <option>1</option>
          <option>2</option>
          <option>3</option>
          <option>4</option>
          <option>5</option>
          <option>6</option>
          <option>7</option>
          <option>8</option>
          <option>9</option>
          <option>10</option>
          <option>11</option>
          <option>12</option>
        </select>
        月
        <span id="gz"> </span> 
      </p>
  </div>
    </td>
  </tr>
  <tr>
    <td align="center" valign="top">
<div id="calendar">
      <div id="detail">
        <div id="datedetail"></div>
        <div id="festival"></div>
      </div>
      <table id="calendarhead">
        <tr>
          <td>日</td>
          <td>一</td>
          <td>二</td>
          <td>三</td>
          <td>四</td>
          <td>五</td>
          <td>六</td>
        </tr>
      </table>
      <table id="week">
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(0)" id="sd0"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(1)" id="sd1"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(2)" id="sd2"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(3)" id="sd3"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(4)" id="sd4"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(5)" id="sd5"></td>
          <td class="agreen" οnmοuseοut="mOut()" οnmοuseοver="mOvr(6)" id="sd6"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(0)" id="ld0"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(1)" id="ld1"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(2)" id="ld2"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(3)" id="ld3"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(4)" id="ld4"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(5)" id="ld5"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(6)" id="ld6"></td>
        </tr>
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(7)" id="sd7"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(8)" id="sd8"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(9)" id="sd9"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(10)" id="sd10"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(11)" id="sd11"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(12)" id="sd12"></td>
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(13)" id="sd13"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(7)" id="ld7"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(8)" id="ld8"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(9)" id="ld9"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(10)" id="ld10"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(11)" id="ld11"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(12)" id="ld12"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(13)" id="ld13"></td>
        </tr>
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(14)" id="sd14"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(15)" id="sd15"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(16)" id="sd16"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(17)" id="sd17"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(18)" id="sd18"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(19)" id="sd19"></td>
          <td class="agreen" οnmοuseοut="mOut()" οnmοuseοver="mOvr(20)" id="sd20"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(14)" id="ld14"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(15)" id="ld15"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(16)" id="ld16"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(17)" id="ld17"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(18)" id="ld18"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(19)" id="ld19"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(20)" id="ld20"></td>
        </tr>
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(21)" id="sd21"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(22)" id="sd22"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(23)" id="sd23"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(24)" id="sd24"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(25)" id="sd25"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(26)" id="sd26"></td>
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(27)" id="sd27"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(21)" id="ld21"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(22)" id="ld22"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(23)" id="ld23"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(24)" id="ld24"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(25)" id="ld25"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(26)" id="ld26"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(27)" id="ld27"></td>
        </tr>
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(28)" id="sd28"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(29)" id="sd29"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(30)" id="sd30"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(31)" id="sd31"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(32)" id="sd32"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(33)" id="sd33"></td>
          <td class="agreen" οnmοuseοut="mOut()" οnmοuseοver="mOvr(34)" id="sd34"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(28)" id="ld28"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(29)" id="ld29"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(30)" id="ld30"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(31)" id="ld31"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(32)" id="ld32"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(33)" id="ld33"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(34)" id="ld34"></td>
        </tr>
        <tr class="tr1">
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(35)" id="sd35"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(36)" id="sd36"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(37)" id="sd37"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(38)" id="sd38"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(39)" id="sd39"></td>
          <td class="one" οnmοuseοut="mOut()" οnmοuseοver="mOvr(40)" id="sd40"></td>
          <td class="aorange" οnmοuseοut="mOut()" οnmοuseοver="mOvr(41)" id="sd41"></td>
        </tr>
        <tr class="tr2">
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(35)" id="ld35"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(36)" id="ld36"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(37)" id="ld37"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(38)" id="ld38"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(39)" id="ld39"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(40)" id="ld40"></td>
          <td οnmοuseοut="mOut()" οnmοuseοver="mOvr(41)" id="ld41"></td>
        </tr>
      </table>
  </div>
    </td>
    <td valign="top">
<div id="panel" style="text-align:center">
      <div οnclick="pushBtm('YU')">上一年↑</div>
      <div οnclick="pushBtm('YD')">下一年↓</div>
      <div οnclick="pushBtm('MU')">上一月↑</div>
      <div οnclick="pushBtm('MD')">下一月↓</div>
      <div οnclick="pushBtm('')">当前月</div>
  </div>
    </td>
  </tr>
  </table>
 </td>
  </tr>
</table>
</body>
</html>


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值