微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 微波和射频技术 > 微波射频仿真学习讨论 > 容火狐的日期代码 带农历

容火狐的日期代码 带农历

时间:10-02 整理:3721RD 点击:

  1. <script type="text/javascript">var now=new Date();</script>
  2. <script language=javascript>
  3. var lunarinfo=new Array(0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,
  4. 0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,
  5. 0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,
  6. 0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,
  7. 0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,
  8. 0x06ca0,0x0b550,0x15355,0x04da0,0x0a5d0,0x14573,0x052d0,0x0a9a8,0x0e950,0x06aa0,
  9. 0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,
  10. 0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b5a0,0x195a6,
  11. 0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,
  12. 0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,
  13. 0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,
  14. 0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,
  15. 0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,
  16. 0x05aa0,0x076a3,0x096d0,0x04bd7,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,
  17. 0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0);
  18. //==== 传回农历 y年的总天数
  19. function lyeardays(y) {
  20. var i, sum = 348
  21. for(i=0x8000; i>0x8; i>>=1) sum += (lunarinfo[y-1900] & i)? 1: 0
  22. return(sum+leapdays(y))
  23. }
  24. //==== 传回农历 y年闰月的天数
  25. function leapdays(y) {
  26. if(leapmonth(y)) return((lunarinfo[y-1900] & 0x10000)? 30: 29)
  27. else return(0)
  28. }
  29. //==== 传回农历 y年闰哪个月 1-12 , 没闰传回 0
  30. function leapmonth(y) { return(lunarinfo[y-1900] & 0xf)}
  31. //====================================== 传回农历 y年m月的总天数
  32. function monthdays(y,m) { return( (lunarinfo[y-1900] & (0x10000>>m))? 30: 29 )}
  33. //==== 算出农历, 传入日期物件, 传回农历日期物件
  34. // 该物件属性有 .year .month .day .isleap .yearcyl .daycyl .moncyl
  35. function lunar(objdate) {
  36. var i, leap=0, temp=0;
  37. var basedate = new Date(1900,0,31);
  38. var offset = (objdate - basedate)/86400000;
  39. var day="";
  40. var myweekday="";
  41. mydate=new Date();
  42. myweekday=mydate.getDay();
  43. if(myweekday == 0)
  44. weekday=" 星期日 ";
  45. else if(myweekday == 1)
  46. weekday=" 星期一 ";
  47. else if(myweekday == 2)
  48. weekday=" 星期二 ";
  49. else if(myweekday == 3)
  50. weekday=" 星期三 ";
  51. else if(myweekday == 4)
  52. weekday=" 星期四 ";
  53. else if(myweekday == 5)
  54. weekday=" 星期五 ";
  55. else if(myweekday == 6)
  56. weekday=" 星期六 ";
  57. this.daycyl = offset + 40;
  58. this.moncyl = 14;
  59. for(i=1900; i<2050 && offset>0; i++) {
  60. temp = lyeardays(i);
  61. offset -= temp;
  62. this.moncyl += 12;
  63. }
  64. if(offset<0) {
  65. offset += temp;
  66. i--;
  67. this.moncyl -= 12;
  68. }
  69. this.year = i;
  70. this.yearcyl = i-1864;
  71. leap = leapmonth(i); //闰哪个月
  72. this.isleap = false
  73. for(i=1; i<13 && offset>0; i++) {
  74. //闰月
  75. if(leap>0 && i==(leap+1) && this.isleap==false)
  76. { --i; this.isleap = true; temp = leapdays(this.year); }
  77. else
  78. { temp = monthdays(this.year, i); }
  79. //解除闰月
  80. if(this.isleap==true && i==(leap+1)) this.isleap = false
  81. offset -= temp
  82. if(this.isleap == false) this.moncyl ++
  83. }
  84. if(offset==0 && leap>0 && i==leap+1)
  85. if(this.isleap)
  86. { this.isleap = false; }
  87. else
  88. { this.isleap = true; --i; --this.moncyl;}
  89. if(offset<0){ offset += temp; --i; --this.moncyl; }
  90. this.month = i
  91. this.day = offset + 1
  92. }
  93. function cday(m,d){
  94. var nstr1 = new Array('日','一','二','三','四','五','六','七','八','九','十');
  95. var nstr2 = new Array('初','十','廿','卅',' ');
  96. var s;
  97. if (m>10){s = '十'+nstr1[m-10]} else {s = nstr1[m]} s += '月'
  98. if (s=="十二月") s = "腊月";
  99. if (s=="一月") s = "正月";
  100. switch (d) {
  101. case 10:s += '初十'; break;
  102. case 20:s += '二十'; break;
  103. case 30:s += '三十'; break;
  104. default:s += nstr2[Math.floor(d/10)]; s += nstr1[d%10];
  105. }
  106. return(s);
  107. }
  108. function solarday2(){
  109. var sdobj = new Date(now.getFullYear(),now.getMonth(),now.getDate());
  110. var ldobj = new lunar(sdobj);
  111. var cl = '';
  112. //农历bb'+(cld[d].isleap?'闰 ':' ')+cld[d].lmonth+' 月 '+cld[d].lday+' 日
  113. var tt = cday(ldobj.month,ldobj.day);
  114. document.write("今天是:"+now.getFullYear()+"年"+(now.getMonth()+1)+"月"+now.getDate()+"日"+ weekday + " 农历"+tt+"");
  115. }
  116. solarday2();
  117. </script>

复制代码

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top