實現陽曆和農曆顯示日期的javascript程式碼
當前大多數網站顯示時間日期的格式都是陽曆的,因為中國已經與世界接軌了嘛。但是中國還是一個傳統大國,有自己的一套曆法,當前還是非常的常用,下面就是一段程式碼例項,能夠實現顯示陽曆和農曆的效果,由於程式碼實在是有點長,並且也比較簡單,這裡就不多做介紹了,有興趣的朋友可以自己做一下分析即可。
程式碼如下:
[HTML] 純文字檢視 複製程式碼執行程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</title> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script type="text/javascript"> /*獲取當前日期*/ function getCurrentDateTime() { var d = new Date(); var year = d.getFullYear(); var month = d.getMonth() + 1; var date = d.getDate(); var week = d.getDay(); /*時分秒*/ /*var hours = d.getHours(); var minutes = d.getMinutes(); var seconds = d.getSeconds(); var ms = d.getMilliseconds();*/ var curDateTime = year; if (month > 9) curDateTime = curDateTime + "年" + month; else curDateTime = curDateTime + "年0" + month; if (date > 9) curDateTime = curDateTime + "月" + date + "日"; else curDateTime = curDateTime + "月0" + date + "日"; /*if (hours > 9) curDateTime = curDateTime + " " + hours; else curDateTime = curDateTime + " 0" + hours; if (minutes > 9) curDateTime = curDateTime + ":" + minutes; else curDateTime = curDateTime + ":0" + minutes; if (seconds > 9) curDateTime = curDateTime + ":" + seconds; else curDateTime = curDateTime + ":0" + seconds;*/ var weekday = ""; if (week == 0) weekday = "星期日"; else if (week == 1) weekday = "星期一"; else if (week == 2) weekday = "星期二"; else if (week == 3) weekday = "星期三"; else if (week == 4) weekday = "星期四"; else if (week == 5) weekday = "星期五"; else if (week == 6) weekday = "星期六"; curDateTime = curDateTime + " " + weekday; return curDateTime; } /*獲取當前農曆*/ function showCal(){ var D=new Date(); var yy=D.getFullYear(); var mm=D.getMonth()+1; var dd=D.getDate(); var ww=D.getDay(); var ss=parseInt(D.getTime() / 1000); if (yy<100) yy="19"+yy; return GetLunarDay(yy,mm,dd); } //定義全域性變數 var CalendarData=new Array(100); var madd=new Array(12); var tgString="甲乙丙丁戊己庚辛壬癸"; var numString="一二三四五六七八九十"; var monString="正二三四五六七八九十冬臘"; var weekString="日一二三四五六"; var sx="鼠牛虎兔龍蛇馬羊猴雞狗豬"; var cYear,cMonth,cDay,TheDate; CalendarData = new Array(0xA4B,0x5164B,0x6A5,0x6D4,0x415B5,0x2B6,0x957,0x2092F,0x497,0x60C96,0xD4A,0xEA5,0x50DA9,0x5AD,0x2B6,0x3126E, 0x92E,0x7192D,0xC95,0xD4A,0x61B4A,0xB55,0x56A,0x4155B, 0x25D,0x92D,0x2192B,0xA95,0x71695,0x6CA,0xB55,0x50AB5,0x4DA,0xA5B,0x30A57,0x52B,0x8152A,0xE95,0x6AA,0x615AA,0xAB5,0x4B6,0x414AE,0xA57,0x526,0x31D26,0xD95,0x70B55,0x56A,0x96D,0x5095D,0x4AD,0xA4D,0x41A4D,0xD25,0x81AA5,0xB54,0xB6A,0x612DA,0x95B,0x49B,0x41497,0xA4B,0xA164B, 0x6A5,0x6D4,0x615B4,0xAB6,0x957,0x5092F,0x497,0x64B, 0x30D4A,0xEA5,0x80D65,0x5AC,0xAB6,0x5126D,0x92E,0xC96,0x41A95,0xD4A,0xDA5,0x20B55,0x56A,0x7155B,0x25D,0x92D,0x5192B,0xA95,0xB4A,0x416AA,0xAD5,0x90AB5,0x4BA,0xA5B, 0x60A57,0x52B,0xA93,0x40E95); madd[0]=0; madd[1]=31; madd[2]=59; madd[3]=90; madd[4]=120; madd[5]=151; madd[6]=181; madd[7]=212; madd[8]=243; madd[9]=273; madd[10]=304; madd[11]=334; function GetBit(m,n){ return (m>>n)&1; } //農曆轉換 function e2c(){ TheDate= (arguments.length!=3) ? new Date() : new Date(arguments[0],arguments[1],arguments[2]); var total,m,n,k; var isEnd=false; var tmp=TheDate.getYear(); if(tmp<1900){ tmp+=1900; } total=(tmp-1921)*365+Math.floor((tmp-1921)/4)+madd[TheDate.getMonth()]+TheDate.getDate()-38; if(TheDate.getYear()%4==0&&TheDate.getMonth()>1) { total++; } for(m=0;;m++){ k=(CalendarData[m]<0xfff)?11:12; for(n=k;n>=0;n--){ if(total<=29+GetBit(CalendarData[m],n)){ isEnd=true; break; } total=total-29-GetBit(CalendarData[m],n); } if(isEnd) break; } cYear=1921 + m; cMonth=k-n+1; cDay=total; if(k==12){ if(cMonth==Math.floor(CalendarData[m]/0x10000)+1){ cMonth=1-cMonth; } if(cMonth>Math.floor(CalendarData[m]/0x10000)+1){ cMonth--; } } } function GetcDateString(){ var tmp=""; /*顯示農曆年:( 如:甲午(馬)年 )*/ /*tmp+=tgString.charAt((cYear-4)%10); tmp+=dzString.charAt((cYear-4)%12); tmp+="("; tmp+=sx.charAt((cYear-4)%12); tmp+=")年 ";*/ if(cMonth<1){ tmp+="(閏)"; tmp+=monString.charAt(-cMonth-1); } else{ tmp+=monString.charAt(cMonth-1); } tmp+="月"; tmp+=(cDay<11)?"初":((cDay<20)?"十":((cDay<30)?"廿":"三十")); if (cDay%10!=0||cDay==10){ tmp+=numString.charAt((cDay-1)%10); } return tmp; } function GetLunarDay(solarYear,solarMonth,solarDay){ //solarYear = solarYear<1900?(1900+solarYear):solarYear; if(solarYear<1921 || solarYear>2020){ return ""; } else{ solarMonth = (parseInt(solarMonth)>0) ? (solarMonth-1) : 11; e2c(solarYear,solarMonth,solarDay); return GetcDateString(); } } $(function(){ var date = getCurrentDateTime(); var calendar = showCal(); $("#currentDate").text("今天是: " + date + "農曆:" + calendar); }); </script> </head> <body> <div id="currentDate"></div> </body> </html>
相關文章
- 公曆日期轉農曆日期
- PHP獲取農曆、陽曆轉陰曆PHP
- angular 日期(陽曆)Angular
- win10 日曆怎麼顯示農曆_win10日曆不顯示農曆怎麼辦Win10
- vue之實現日曆----顯示農曆,滾動日曆監聽年月改變Vue
- Win10系統日曆應用顯示農曆日期的方法【圖文】Win10
- win10在日曆裡顯示天氣和農曆的方法_win10怎麼讓日曆磁貼顯示農曆和天氣Win10
- win10電腦日曆怎麼顯示農曆_win10系統日曆顯示農曆的設定方法Win10
- js實現的輸出當前農曆日期JS
- 點選日曆顯示日期jqueryjQuery
- jQuery手機移動端農曆公曆日期時間選擇程式碼jQuery
- win10系統如何設定時間日期顯示農曆Win10
- JavaScript 實現日曆式日期選擇 (轉)JavaScript
- win10 系統怎麼設定日曆顯示節日_win10日曆要怎麼顯示農曆Win10
- win10專業版右下角顯示農曆的方法_win10專業版電腦右下角的日曆怎麼顯示農曆Win10
- 陽曆到陰曆的轉換 (轉)
- 陽曆和陰曆相互轉化的工具類 golang版本Golang
- win10桌面農曆怎麼顯示_win10如何設定農曆在桌面上Win10
- 根據公曆計算農曆
- Kalendae:JavaScript日期選擇和日曆控制元件JavaScript控制元件
- PHP實現的簡單日曆程式碼PHP
- Android自定義預定日曆,並且顯示陰曆Android
- JavaScript日曆效果程式碼例項JavaScript
- Vue日曆的編寫,可顯示周和月的模式(其中可以自定義日曆裡內容的顯示)Vue模式
- JavaScript年月日日期顯示程式碼JavaScript
- 用Delphi處理公曆到農曆的轉換 (轉)
- 原生JavaScript實現造日曆輪子JavaScript
- 農曆的演算法 (轉)演算法
- JavaScript簡單的日曆效果程式碼例項JavaScript
- win10 如何桌面顯示日曆 win10怎麼在電腦桌面顯示日曆Win10
- win10日曆顯示日程安排的方法_win10如何讓日曆顯示日程安排Win10
- 微信小程式實現簽到的日曆微信小程式
- c#農曆開源庫C#
- C語言實現萬年曆程式C語言
- delphi 控制元件 LssCalendar V2.0 (支援農曆的月曆控制元件)控制元件
- 記新專案中遇到的有關農曆,日曆元件的所有問題。元件
- javascript日曆外掛JavaScript
- Android 簽到打卡日曆,自定義日期可帶圖示(附原始碼)Android原始碼