获取阴历(农历)和当前日期的js代码


Posted in Javascript onFebruary 15, 2016

本文为大家分享了一段js显示阴历(农历)和当前日期的关键性代码,供大家参考,具体内容如下

var CalendarData=new Array(100);
var madd=new Array(12);
var tgString="甲乙丙丁戊己庚辛壬癸";
var dzString="子丑寅卯辰巳午未申酉戌亥";
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();
}
}
 
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;
function showCal(){
document.write(GetLunarDay(yy,mm,dd));
}

页面调用代码:

<script language="JavaScript" type="text/javascript" src="getCNdate.js"></script>
 
<script type="text/javascript">showCal();</script>

代码二:用JavaScript获取当前农历日期

<script type="text/javascript">
 var sWeek = new Array("星期日","星期一","星期二","星期三","星期四","星期五","星期六");
 var dNow = new Date();
 var CalendarData=new Array(100);var madd=new Array(12);var tgString="甲乙丙丁戊己庚辛壬癸";var dzString="子丑寅卯辰巳午未申酉戌亥";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.getFullYear(); 
 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+="年 "; 
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)
{
 if (solarYear<1921 || solarYear>2020) {     return ""; 
 }    else    {     solarMonth = (parseInt(solarMonth)>0) ? (solarMonth-1) : 11;     e2c(solarYear,solarMonth,solarDay); return GetcDateString();    }}
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); 
function getFullYear(d){// 修正firefox下year错误
yr=d.getYear();if(yr<1000)
yr+=1900;return yr;}
function showDate() {
 var sValue = getFullYear(dNow)+"年"+(dNow.getMonth()+1)+"月"+dNow.getDate()+"日"+" "+sWeek[dNow.getDay()]+" ";
 sValue+=GetLunarDay(yy,mm,dd);
   document.getElementById("pDate").innerHTML = sValue;
};
window.onload=showDate;
</script>

知道如何获取农历,如何呢获取当前日期也很简单。

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;
}

页面调用代码:

<script language="JavaScript" type="text/javascript" src="getToday.js"></script>

希望本文所述对大家利用js代码获取阴历(农历)日期有所帮助,抓紧收藏起来吧!

Javascript 相关文章推荐
getElementsByTagName vs selectNodes效率 及兼容的selectNodes实现
Feb 26 Javascript
js修改原型的属性使用介绍
Jan 26 Javascript
浅谈JavaScript中的对象及Promise对象的实现
Nov 15 Javascript
Angular实现form自动布局
Jan 28 Javascript
js微信支付实现代码
Dec 22 Javascript
EasyUI修改DateBox和DateTimeBox的默认日期格式示例
Jan 18 Javascript
Bootstrap响应式导航由768px变成992px的实现代码
Jun 15 Javascript
JS实现点击复选框变更DIV显示状态的示例代码
Dec 18 Javascript
redux-saga 初识和使用
Mar 10 Javascript
Webpack中publicPath路径问题详解
May 03 Javascript
详解关于webpack多入口热加载很慢的原因
Apr 24 Javascript
vue组件暴露和.js文件暴露接口操作
Aug 11 Javascript
极易被忽视的javascript面试题七问七答
Feb 15 #Javascript
在JavaScript中使用JSON数据
Feb 15 #Javascript
三分钟带你玩转jQuery.noConflict()
Feb 15 #Javascript
轻松搞定jQuery.noConflict()
Feb 15 #Javascript
JavaScript的Backbone.js框架的一些使用建议整理
Feb 14 #Javascript
简单了解Backbone.js的Model模型以及View视图的源码
Feb 14 #Javascript
Backbone.js框架中简单的View视图编写学习笔记
Feb 14 #Javascript
You might like
php 使用GD库为页面增加水印示例代码
2014/03/24 PHP
Laravel路由设定和子路由设定实例分析
2016/03/30 PHP
遍历指定目录,并存储目录内所有文件属性信息的php代码
2016/10/28 PHP
PNG背景在不同浏览器下的应用
2009/06/22 Javascript
一个封装js代码-----展开收起效果示例
2013/07/03 Javascript
javascript模拟订火车票和退票示例
2014/04/24 Javascript
Javascript数据结构与算法之列表详解
2015/03/12 Javascript
jQuery实现仿Google首页拖动效果的方法
2015/05/04 Javascript
JQuery中两个ul标签的li互相移动实现方法
2015/05/18 Javascript
购物车前端开发(jQuery和bootstrap3)
2016/08/27 Javascript
JavaScript九九乘法口诀表的简单实现
2016/10/04 Javascript
详解JS: reduce方法实现 webpack多文件入口
2017/02/14 Javascript
从零开始学习Node.js系列教程五:服务器监听方法示例
2017/04/13 Javascript
JS库之Three.js 简易入门教程(详解之一)
2017/09/13 Javascript
vue中监听路由参数的变化及方法
2019/12/06 Javascript
Javascript实现鼠标点击冒泡特效
2019/12/24 Javascript
JavaScript实现图片放大预览效果
2020/11/02 Javascript
[02:16]DOTA2英雄基础教程 干扰者
2014/01/15 DOTA
python中去空格函数的用法
2014/08/21 Python
python中self原理实例分析
2015/04/30 Python
Python操作串口的方法
2015/06/17 Python
Python的collections模块中namedtuple结构使用示例
2016/07/07 Python
django实现同一个ip十分钟内只能注册一次的实例
2017/11/03 Python
python的unittest测试类代码实例
2017/12/07 Python
python使用json序列化datetime类型实例解析
2018/02/11 Python
对Django的restful用法详解(自带的增删改查)
2019/08/28 Python
Python pip 安装与使用(安装、更新、删除)
2019/10/06 Python
pytorch下使用LSTM神经网络写诗实例
2020/01/14 Python
详解pycharm配置python解释器的问题
2020/10/15 Python
python爬虫如何解决图片验证码
2021/02/14 Python
老人祝寿主持词
2014/03/28 职场文书
2014年社区居委会主任重阳节讲话稿
2014/09/25 职场文书
社区学习党的群众路线教育实践活动心得体会
2014/11/03 职场文书
教师个人工作总结范文2014
2014/11/10 职场文书
公司市场部岗位职责
2015/04/15 职场文书
python源码剖析之PyObject详解
2021/05/18 Python