本文实例讲述了JS简单获取当前日期和农历日期的方法。分享给大家供大家参考,具体如下:

navCal.js文件如下:

today=new Date();

function initArray(){

this.length=initArray.arguments.length

for(var i=0;i

this[i+1]=initArray.arguments[i] }

var d=new initArray(

"星期日",

"星期一",

"星期二",

"星期三",

"星期四",

"星期五",

"星期六");

document.write(today.getFullYear(),"年",today.getMonth()+1,"月",today.getDate(),"日 ",d[today.getDay()+1]," ");

calendar = new Date();

month = calendar.getMonth();

date = calendar.getDate();

if ((month == 0) && (date == 1)) document.write("元旦");

if ((month == 2) && (date == 12)) document.write("植树节");

if ((month == 3) && (date == 5)) document.write("清明节");

if ((month == 4) && (date == 1)) document.write("国际劳动节");

if ((month == 4) && (date == 4)) document.write("青年节");

if ((month == 5) && (date == 1)) document.write("国际儿童节");

if ((month == 7) && (date == 1)) document.write("建军节");

if ((month == 7) && (date == 16)) document.write("七夕情人节");

if ((month == 9) && (date == 1)) document.write("国庆节/国际音乐节/国际老人节");

if ((month == 11) && (date == 24)) document.write("平安夜");

if ((month == 11) && (date == 25)) document.write("圣诞节");

/*农历部分*/

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

}

showCal();

调用方法:

运行效果图如下:

PS:这里再为大家推荐几款日历相关在线工具供大家参考:

另外,本站历史上的今天也有相似的农历日期显示功能:

希望本文所述对大家JavaScript程序设计有所帮助。

js 万年历农历转阳历 方法_JS简单获取当前日期和农历日期的方法相关推荐

  1. js title 单选框 获取_js简单获取表单中单选按钮值的方法

    本文实例讲述了js简单获取表单中单选按钮值的方法.分享给大家供大家参考,具体如下: HTML部分如下: bordercolor="#999999">回退类型: type=&q ...

  2. html单选按钮值的读取,js简单获取表单中单选按钮值的方法

    本文实例讲述了js简单获取表单中单选按钮值的方法.分享给大家供大家参考,具体如下: HTML部分如下: bordercolor="#999999">回退类型: type=&q ...

  3. 【EventBus】事件通信框架 ( 订阅方法注册 | 检查订阅方法缓存 | 反射获取订阅类中的订阅方法 )

    文章目录 一.检查订阅方法缓存 二.反射获取订阅类中的订阅方法 三.完整代码示例 一.检查订阅方法缓存 注册订阅者时 , 只传入一个订阅者类对象 , 其它信息都需要通过反射获取 ; 1. 获取订阅者类 ...

  4. java获取当前日期 星期几_java获取当前日期是星期几的方法

    java获取当前日期是星期几的方法 发布时间:2020-06-29 11:16:15 来源:亿速云 阅读:133 作者:Leah 本篇文章为大家展示了java获取当前日期是星期几的方法,代码简明扼要并 ...

  5. 微信小程序简单获取当前时间及日期

    微信小程序获取当前时间,显示当前时间或者使用当前时间进行一些判断,也是一件很重要的评判标准. 下面介绍一下如何简单获取当前时间的方法吧! 首先需要在需要使用到时间的页面进行导入获取时间的util.js ...

  6. 【JS】 # js获取当前日期,比较日期大小

    通过 JS 在前台页面获取当前日期,比较时间的大小 // 获取当前时间,格式YYYY-MM-DD function getNowFormatDate() {var date = new Date(); ...

  7. Js获取当前日期和农历日期

    today=new Date(); function initArray(){this.length=initArray.arguments.lengthfor(var i=0;i<this.l ...

  8. htm显示日期与农历 html,获取当前日期和农历的js代码

    var CalendarData = new Array(100);var madd = new Array(12);var tgString = "甲乙丙丁戊己庚辛壬癸";var ...

  9. java获取当前日期和时间(各种方法对比)

    文章目录 一.简介 二.使用 1.获取当前时间的毫秒值 2.获取当前的时间 3.获取当前的日期(相对于月) 4.SimpleDateFormat中格式化字符的含义 5.YYYY与yyyy区别 三.JD ...

  10. java 获取私有方法_如何获取java类里的私有方法

    展开全部 利用java的反射机制,以下代码:public class Main { private void fun(){ 32313133353236313431303231363533e4b893 ...

最新文章

  1. iOS学习之路十三(动态调整UITableViewCell的高度)
  2. 美媒全球大学排名:清华超麻理跃居计算机专业第一
  3. NT式驱动和WDM式驱动程序
  4. [总结]Asp.net中的页面乱码的问题
  5. 封装的适配器 adapter
  6. Tensorflow中的Protocol Buffer
  7. 解决开机后自动重起问题
  8. 安卓应用出海指南--发布到Google Play
  9. 解剖 Facebook 底层
  10. rat linux安装u盘,美加狮RAT2鼠标驱动
  11. 神秘AI变脸软件风靡全球,让你秒变身迪士尼在逃主角
  12. 有哪位仁兄可以告诉我,下载软件包的时候出现这种情况是怎么一回事呢?kali虚拟机,希望看见的前辈不吝赐教
  13. KMP的next迷思
  14. NVIDIA Jetson Nano/Xavier NX 扩容教程
  15. 1258:【例9.2】数字金字塔
  16. 如何区分网线是几类的_怎么能从网线上看出网线是几类线~请高手帮帮忙~先谢谢了...
  17. Python爬虫快速入门:基本结构简单实例
  18. 计算机网络技术第七章
  19. ios-block-对象与对象之间的解偶合
  20. elasticsearch实现博客搜索_(eblog)9、博客搜索引擎开发、后台精选

热门文章

  1. 百度2017春招笔试真题编程题集合 [编程题]买帽子
  2. PS与qq热键设置雷同
  3. [ahk]热键呼叫QQ经常聊天的人
  4. 如何读书阅读--每天一本书计划
  5. MAUI 跨平台应用开发实战
  6. 最好的Linux文件管理器,适用于 Linux 用户的 10 款优秀且免费的文件管理器
  7. 解决”企业证书打包的ipa,点击app提示未受信任的企业级开发者“的问题
  8. D. Three Religions
  9. linux vrrp 配置命令,虚拟路由器冗余协议(VRRP)简单实验
  10. 供应链金融业务信息化平台搭建要点分享