jQuery日程管理插件fullcalendar使用详解

FullCalendar用来做日程管理功能非常强大,但是唯一不足的地方是没有将中国农历历法加进去,今天我将结合实例和大家分享如何将中国农历中的节气和节日整合到FullCalendar中,从而增强其实用性。

HTML

首先是要载入jQuery库和fullcalendar插件。

<script src='js/jquery-1.9.1.min.js'></script>
<script src='js/fullcalendar.min.js'></script>

然后在body中,建立日历容器div#calendar。

<div id="calendar"></div>

jQuery

使用jQuery调用fullcalendar插件,方法如下,值得一提的是events数据源来自json.php,这个PHP文件负责读取数据并返回json格式的日程安排数据给前端。

$(function() {
  $('#calendar').fullCalendar({
    header: {
      left: 'prev,next today',
      center: 'title',
      right: 'month,agendaWeek,agendaDay'
    },
    selectable: true,
    events: 'json.php' //数据源
  });
});

以上代码就可以展示一个日历界面,但是需要加入农历,则需要将农历算法代码整合到fullCalendar中,并且需要将fullCalendar.js中的代码稍微改动下,以下是网友@太空飛豬以及/可爱/玫瑰提供的中国农历算法javascript版,再此一并感谢!

function RunGLNL() {
  var today = new Date();
  var d = new Array("周日", "周一", "周二", "周三", "周四", "周五", "周六");
  var DDDD = d[today.getDay()];
  DDDD = DDDD + " " + (CnDateofDateStr(today)); //显示农历
  DDDD = DDDD + SolarTerm(today); //显示二十四节气
  document.write(DDDD);
}
function DaysNumberofDate(DateGL) {
  return parseInt((Date.parse(DateGL) - Date.parse(DateGL.getFullYear() + "/1/1")) / 86400000) + 1;
}
function CnDateofDate(DateGL) {
  var CnData = new Array(
    0x16, 0x2a, 0xda, 0x00, 0x83, 0x49, 0xb6, 0x05, 0x0e, 0x64, 0xbb, 0x00, 0x19, 0xb2, 0x5b, 0x00,
    0x87, 0x6a, 0x57, 0x04, 0x12, 0x75, 0x2b, 0x00, 0x1d, 0xb6, 0x95, 0x00, 0x8a, 0xad, 0x55, 0x02,
    0x15, 0x55, 0xaa, 0x00, 0x82, 0x55, 0x6c, 0x07, 0x0d, 0xc9, 0x76, 0x00, 0x17, 0x64, 0xb7, 0x00,
    0x86, 0xe4, 0xae, 0x05, 0x11, 0xea, 0x56, 0x00, 0x1b, 0x6d, 0x2a, 0x00, 0x88, 0x5a, 0xaa, 0x04,
    0x14, 0xad, 0x55, 0x00, 0x81, 0xaa, 0xd5, 0x09, 0x0b, 0x52, 0xea, 0x00, 0x16, 0xa9, 0x6d, 0x00,
    0x84, 0xa9, 0x5d, 0x06, 0x0f, 0xd4, 0xae, 0x00, 0x1a, 0xea, 0x4d, 0x00, 0x87, 0xba, 0x55, 0x04
  );
  var CnMonth = new Array();
  var CnMonthDays = new Array();
  var CnBeginDay;
  var LeapMonth;
  var Bytes = new Array();
  var I;
  var CnMonthData;
  var DaysCount;
  var CnDaysCount;
  var ResultMonth;
  var ResultDay;
  var yyyy = DateGL.getFullYear();
  var mm = DateGL.getMonth() + 1;
  var dd = DateGL.getDate();
  if (yyyy < 100) yyyy += 1900;
  if ((yyyy < 1997) || (yyyy > 2020)) {
    return 0;
  }
  Bytes[0] = CnData[(yyyy - 1997) * 4];
  Bytes[1] = CnData[(yyyy - 1997) * 4 + 1];
  Bytes[2] = CnData[(yyyy - 1997) * 4 + 2];
  Bytes[3] = CnData[(yyyy - 1997) * 4 + 3];
  if ((Bytes[0] & 0x80) != 0) {
    CnMonth[0] = 12;
  }
  else {
    CnMonth[0] = 11;
  }
  CnBeginDay = (Bytes[0] & 0x7f);
  CnMonthData = Bytes[1];
  CnMonthData = CnMonthData << 8;
  CnMonthData = CnMonthData | Bytes[2];
  LeapMonth = Bytes[3];
  for (I = 15; I >= 0; I--) {
    CnMonthDays[15 - I] = 29;
    if (((1 << I) & CnMonthData) != 0) {
      CnMonthDays[15 - I]++;
    }
    if (CnMonth[15 - I] == LeapMonth) {
      CnMonth[15 - I + 1] = -LeapMonth;
    }
    else {
      if (CnMonth[15 - I] < 0) {
        CnMonth[15 - I + 1] = -CnMonth[15 - I] + 1;
      }
      else {
        CnMonth[15 - I + 1] = CnMonth[15 - I] + 1;
      }
      if (CnMonth[15 - I + 1] > 12) {
        CnMonth[15 - I + 1] = 1;
      }
    }
  }
  DaysCount = DaysNumberofDate(DateGL) - 1;
  if (DaysCount <= (CnMonthDays[0] - CnBeginDay)) {
    if ((yyyy > 1901) && (CnDateofDate(new Date((yyyy - 1) + "/12/31")) < 0)) {
      ResultMonth = -CnMonth[0];
    }
    else {
      ResultMonth = CnMonth[0];
    }
    ResultDay = CnBeginDay + DaysCount;
  }
  else {
    CnDaysCount = CnMonthDays[0] - CnBeginDay;
    I = 1;
    while ((CnDaysCount < DaysCount) && (CnDaysCount + CnMonthDays[I] < DaysCount)) {
      CnDaysCount += CnMonthDays[I];
      I++;
    }
    ResultMonth = CnMonth[I];
    ResultDay = DaysCount - CnDaysCount;
  }
  if (ResultMonth > 0) {
    return ResultMonth * 100 + ResultDay;
  }
  else {
    return ResultMonth * 100 - ResultDay;
  }
}
function CnYearofDate(DateGL) {
  var YYYY = DateGL.getFullYear();
  var MM = DateGL.getMonth() + 1;
  var CnMM = parseInt(Math.abs(CnDateofDate(DateGL)) / 100);
  if (YYYY < 100) YYYY += 1900;
  if (CnMM > MM) YYYY--;
  YYYY -= 1864;
  return CnEra(YYYY) + "年";
}
function CnMonthofDate(DateGL) {
  var CnMonthStr = new Array("零", "正", "二", "三", "四", "五", "六", "七", "八", "九", "十", "冬", "腊");
  var Month;
  Month = parseInt(CnDateofDate(DateGL) / 100);
  if (Month < 0) {
    return "闰" + CnMonthStr[-Month] + "月";
  }
  else {
    return CnMonthStr[Month] + "月";
  }
}
function CnDayofDate(DateGL) {
  var CnDayStr = new Array("零",
    "初一", "初二", "初三", "初四", "初五",
    "初六", "初七", "初八", "初九", "初十",
    "十一", "十二", "十三", "十四", "十五",
    "十六", "十七", "十八", "十九", "二十",
    "廿一", "廿二", "廿三", "廿四", "廿五",
    "廿六", "廿七", "廿八", "廿九", "三十");
  var Day;
  Day = (Math.abs(CnDateofDate(DateGL))) % 100;
  //hanlichen mod
  if ("初一" == CnDayStr[Day]) {
    // alert(SolarTerm(DateGL));
    return CnMonthofDate(DateGL);
  } else {
    if (SolarTerm(DateGL) != "") {
      return SolarTerm(DateGL);
    } else {
      return CnDayStr[Day];
    }
  }
}
function DaysNumberofMonth(DateGL) {
  var MM1 = DateGL.getFullYear();
  MM1 < 100 ? MM1 += 1900 : MM1;
  var MM2 = MM1;
  MM1 += "/" + (DateGL.getMonth() + 1);
  MM2 += "/" + (DateGL.getMonth() + 2);
  MM1 += "/1";
  MM2 += "/1";
  return parseInt((Date.parse(MM2) - Date.parse(MM1)) / 86400000);
}
function CnEra(YYYY) {
  var Tiangan = new Array("甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸");
  var Dizhi = new Array("子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥");
  return Tiangan[YYYY % 10] + Dizhi[YYYY % 12];
}
function CnDateofDateStr(DateGL) {
  if (CnMonthofDate(DateGL) == "零月") return " 请调整您的计算机日期!";
  else return "农历" + CnYearofDate(DateGL) + " " + CnMonthofDate(DateGL) + CnDayofDate(DateGL);
} 

function SolarTerm(DateGL) {
  var SolarTermStr = new Array(
    "小寒", "大寒", "立春", "雨水", "惊蛰", "春分",
    "清明", "谷雨", "立夏", "小满", "芒种", "夏至",
    "小暑", "大暑", "立秋", "处暑", "白露", "秋分",
    "寒露", "霜降", "立冬", "小雪", "大雪", "冬至");
  var DifferenceInMonth = new Array(
    1272060, 1275495, 1281180, 1289445, 1299225, 1310355,
    1321560, 1333035, 1342770, 1350855, 1356420, 1359045,
    1358580, 1355055, 1348695, 1340040, 1329630, 1318455,
    1306935, 1297380, 1286865, 1277730, 1274550, 1271556);
  var DifferenceInYear = 31556926;
  var BeginTime = new Date(1901 / 1 / 1);
  BeginTime.setTime(947120460000);
  for (; DateGL.getFullYear() < BeginTime.getFullYear();) {
    BeginTime.setTime(BeginTime.getTime() - DifferenceInYear * 1000);
  }
  for (; DateGL.getFullYear() > BeginTime.getFullYear();) {
    BeginTime.setTime(BeginTime.getTime() + DifferenceInYear * 1000);
  }
  for (var M = 0; DateGL.getMonth() > BeginTime.getMonth(); M++) {
    BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);
  }
  if (DateGL.getDate() > BeginTime.getDate()) {
    BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);
    M++;
  }
  if (DateGL.getDate() > BeginTime.getDate()) {
    BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);
    M == 23 ? M = 0 : M++;
  }
  var JQ = "";
  if (DateGL.getDate() == BeginTime.getDate()) {
    JQ += SolarTermStr[M];
  }
  return JQ;
} 

将以上代码直接复制粘贴到从官网下载的fullcalendar.js的最后。然后关键的是我们要对fullcalendar.js原有的代码中程序日历天数的代码段做修改。

大概在第2385行开始,其中的if语句中的部分修改为以下代码

if (showNumbers) {//月视图天数数字显示
  var cnMonth = CnMonthofDate(date);//农历月
  var cnDay = CnDayofDate(date);//农历日
  var solar = SolarTerm(date);//农历节气
  if(solar!='') cnDay=solar;
  var cnMonDay = cnMonth+cnDay; 

  var holiday = '';
  if(cnDay=='正月')
    holiday = '春节';
  switch(cnMonDay){
    case '正月初一': holiday = '春节';break;
    case '正月十五': holiday = '元宵';break;
    case '五月初五': holiday = '端午';break;
    case '八月十五': holiday = '中秋';break;
    case '九月初九': holiday = '重阳';break;
    case '腊月三十': holiday = '除夕';break;
  } 

  html += "<div class='fc-day-number'><span class='solarday'>"+ cnDay+"</span>
  <span class='holiday'>"+holiday+"</span>" + date.getDate() + "</div>";
}

以上代码中,调用了农历算法,计算出日历中对应的农历日期包括节气,在这里我们还做了特殊节日的处理,比如春节、端午、中秋等,然后我们要将农历与公历以及特殊节日同时显示在fullcalendar中,这时就要修改css来控制使得公历日期显示在左上,农历显示在右上,特殊节日显示在中间。

.fc-grid .fc-day-number{padding: 0 2px; position:relative}
.fc-grid .fc-day-number span.solarday{float:right;color:#999}
.fc-grid .fc-day-number span.holiday{position:absolute; left:40%}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • datePicker——日期选择控件(with jquery)

    demo: http://demo.jb51.net/js/2011/jQuery_calendar/index.html down: http://www.jb51.net/jiaoben/19622.html 用法很简单,而且js文件也很小,之前也见过一些日期选择控件,但个头都比较大,影响速度可以设置日期的格式,可以选择日期的起止时间,如果不加参数的话,默认就是之前的日期不可选,而只能从今天开始选择 现在My97 DatePicker也不错,不用jquery 一款很不错的基于JavaScri

  • jquery UI Datepicker时间控件的使用方法(加强版)

    先来看看Datepicker插件的属性表: 第一个日历插件的使用实例 首先导入需要的类库文件: <</SPAN>scripttype="text/javascript" src="${pageContext.request.contextPath }/js/jquery-1.7.1.min.js"></</SPAN>script> <</SPAN>scripttype="text/javas

  • jquery UI Datepicker时间控件的使用方法(终结版)

    近期项目中用到日期控件,感觉不错,写出来分享给大家看看,我限制的开始时间和结束时间跨度不超过三天,并配置有清空时间,重选时间等功能,分享给大家: 先给大家看两张效果图 在例子中我控制的开始时间和结束时间为三天,也就是开始时间和结束时间的跨度不能超过三天. 具体是怎么实现的,代码中会附有很详细的解释,请大家继续往下看: 第一步,引入控件js,这里有两个,一个是jquery.js,一个是jquery-ui-datepicker.js,当然还有引入样式文件: <script type="text

  • jquery UI Datepicker时间控件冲突问题解决

    公司里的项目由于发展较快,很多东西都没有好好梳理一下,以至于有很多的潜在的问题. 最近就遇到了一个比较坑的问题.datepicker  有两个插件库中的datepicker插件比较有名.一个是jQuery-UI,一个是bootstrap.两个的api网址分别是 然而在项目中很不巧的两个库都用到了.然后就出现了以下情况:http://jqueryui.com/datepicker/   和  http://bootstrap-datepicker.readthedocs.io/en/latest/

  • jQuery日程管理控件glDatePicker用法详解

    本文实例讲述了jQuery日程管理控件glDatePicker用法.分享给大家供大家参考,具体如下: 之前接触过一款日程管理控件,叫 FullCalendar,功能很强大,会列出每天的事项,可选择编辑并且可以定制自己的日历,然而,有时候,我们的网页上只需要一个简单的日历,迷你但实用,有日程安排的日期高亮显示,可跳转日期,可选择日期等等基本功能都应该具备,而这时 FullCalendar 就显得太过庞大了,所以,就有了我对 glDatePicker 控件的学习. 先看效果:    橘红色表示当前选

  • jquery UI Datepicker时间控件的使用方法(基础版)

    本文为大家分享jquery ui datepicker时间控件的使用方法,通过实例讲解了解ui datepicker时间控件,先给大家看一看效果图: 效果: 常用场合: 1.输入框 2.div 使用方法: 1.限制日期 $("#resultDiv").datepicker({ onSelect: function (dateText, inst) { //代码:选择日期后触发的事件 }, minDate: new Date(),//最小日期 maxDate: new Date($(&q

  • JQuery EasyUI 日期控件如何控制日期选择区间

    复制代码 代码如下: <tr><th>发售起始日期</th> <td><input type="text" id="usLineTime" name="usLineTime" size="20" class='easyui-validatebox Wdate' onFocus="WdatePicker({el:'usLineTime',dateFmt:'yyyy-

  • 基于jQuery的日期选择控件

    但是也有些问题,第一画日历有点慢,第二兼容性不太好IE Only,第三它不是基于jQuery的哈哈. 那还是老规矩,做之前先看下效果   这下是更酷的Ext风格了. 从上图我们可以看出这个控件其实有两个视图一个日期月视图,还有一个是年月选择视图. 1:还是先从HTML入手 日期控件确定HTML其实还是比较简单,因为明摆着是列表的数据格式,当然主要是采用table了. 两个视图分别用两个Div包裹,控制div的显示隐藏即可以切换视图了.完整的HTMl结构大家可以用IEDeveloper看一下Dem

  • jquery 日期控件datepicker属性详细解析

    复制代码 代码如下: $("#regDate").datepicker(     {    showMonthAfterYear: true, // 月在年之后显示    changeMonth: true,   // 允许选择月份    changeYear: true,   // 允许选择年份    dateFormat:'yy-mm-dd',  // 设置日期格式    closeText:'关闭',   // 只有showButtonPanel: true才会显示出来    d

  • jquery UI Datepicker时间控件的使用及问题解决

    本文实例为大家分享了jqueryUI中datepicker的使用,解决与asp.net中的UpdatePanel联合使用时的失效问题. 1.jqueryUI的datepicker的使用 -->首先在jqueryUI官网上根据你的需要下载适合你系统主题的样式,jqueryUI主题:下载地址: -->下载后的文件 jquery-ui-1.10.3.custom文件夹:不同的主题的区别在于它们引用的css不同 默认下载的样式如下: 其它样式比如我下载的样式: 下载的jqueryUI中除了css文件夹

随机推荐