使用calendar日历插件实现动态展示会议信息
效果图如下,标红色为有会议安排,并跳转详细会议信息页面。
html页面
<%@ page contentType="text/html;charset=UTF-8"%>
<%@ include file="/WEB-INF/views/include/taglib.jsp"%>
<html>
<head>
<title>会议查询界面</title>
<meta name="decorator" content="default" /> <link href="${ctxStatic}/calendar/images/all.css" rel="stylesheet" type="text/css" />
<link href="${ctxStatic}/calendar/images/skin.css" rel="stylesheet" type="text/css" />
<link href="${ctxStatic}/calendar/images/fontSize12.css" rel="stylesheet" type="text/css" />
<link href="${ctxStatic}/calendar/images/calendar.css" rel="stylesheet" type="text/css" /> <script type="text/javascript" src="${ctxStatic}/calendar/js/jquery.js"></script>
<script type="text/javascript" src="${ctxStatic}/calendar/js/calendar.js"></script> <script type="text/javascript">
$(document).ready(function() { });
function page(n,s){
$("#pageNo").val(n);
$("#pageSize").val(s);
$("#searchForm").submit();
return false;
}
</script>
</head> <body style="height: 98%;">
<div class="main">
<div class="pathBar" style="margin-bottom: 2px;">
<div class="pathBarPos"></div>
</div>
<div id="myrl"
style="width: 820px; margin-left: auto; margin-right: auto; height: 840px; overflow: hidden;">
<form name=CLD>
<table class="biao" width="800px" id="huiyi8">
<tbody>
<tr>
<td class="calTit" colspan=7
style="height: 30px; padding-top: 3px; text-align: center;">
<a href="#" title="上一年" id="nianjian" class="ymNaviBtn lsArrow"></a>
<a href="#" title="上一月" id="yuejian" class="ymNaviBtn lArrow"></a>
<div style="width: 250px; float: left; padding-left: 230px;">
<span id="dateSelectionRili" class="dateSelectionRili"
style="cursor: hand; color: white; border-bottom: 1px solid white;"
onclick="dateSelection.show()"> <span id="nian"
class="topDateFont"></span><span class="topDateFont">年</span><span
id="yue" class="topDateFont"></span><span class="topDateFont">月</span>
<span class="dateSelectionBtn cal_next" onclick="dateSelection.show()">▼</span></span>
<font id=GZ class="topDateFont"></font>
</div> <!--新加导航功能-->
<div style="left: 250px; display: none;" id="dateSelectionDiv">
<div id="dateSelectionHeader"></div>
<div id="dateSelectionBody">
<div id="yearList">
<div id="yearListPrev" onclick="dateSelection.prevYearPage()"><</div>
<div id="yearListContent"></div>
<div id="yearListNext" onclick="dateSelection.nextYearPage()">></div>
</div>
<div id="dateSeparator"></div>
<div id="monthList">
<div id="monthListContent">
<span id="SM0" class="month"
onclick="dateSelection.setMonth(0)">1</span> <span id="SM1"
class="month" onclick="dateSelection.setMonth(1)">2</span>
<span id="SM2" class="month"
onclick="dateSelection.setMonth(2)">3</span> <span id="SM3"
class="month" onclick="dateSelection.setMonth(3)">4</span>
<span id="SM4" class="month"
onclick="dateSelection.setMonth(4)">5</span> <span id="SM5"
class="month" onclick="dateSelection.setMonth(5)">6</span><span
id="SM6" class="month" onclick="dateSelection.setMonth(6)">7</span>
<span id="SM7" class="month"
onclick="dateSelection.setMonth(7)">8</span> <span id="SM8"
class="month" onclick="dateSelection.setMonth(8)">9</span>
<span id="SM9" class="month"
onclick="dateSelection.setMonth(9)">10</span> <span
id="SM10" class="month"
onclick="dateSelection.setMonth(10)">11</span> <span
id="SM11" class="month curr"
onclick="dateSelection.setMonth(11)">12</span>
</div>
<div style="clear: both;"></div>
</div>
<div id="dateSelectionBtn">
<div id="dateSelectionTodayBtn"
onclick="dateSelection.goToday()">今天</div>
<div id="dateSelectionOkBtn" onclick="dateSelection.go()">确定</div>
<div id="dateSelectionCancelBtn"
onclick="dateSelection.hide()">取消</div>
</div>
</div>
<div id="dateSelectionFooter"></div>
</div>
<a href="#" id="nianjia" title="下一年" class="ymNaviBtn rsArrow" style="float: right;"></a>
<a href="#" id="yuejia" title="下一月" class="ymNaviBtn rArrow" style="float: right;"></a>
</td>
</tr>
<tr class="calWeekTit"
style="font-size: 12px; height: 20px; text-align: center;">
<td width="100">星期日</td>
<td width="100">星期一</td>
<td width="100">星期二</td>
<td width="100">星期三</td>
<td width="100">星期四</td>
<td width="100">星期五</td>
<td width="100">星期六</td>
</tr>
<script language="JavaScript">
var gNum;
for (var i = 0; i < 6; i++) {
document.write('<tr align=center height="50" id="tt">');
for (var j = 0; j < 7; j++) {
gNum = i * 7 + j ;
document.write('<td id="GD' + gNum + '" on="0" ><font id="SD' + gNum + '" style="font-size:22px;" face="Arial"');
if (j == 0) document.write('');
if (j == 6)
if (i % 2 == 1) document.write('');
else document.write('');
document.write(' TITLE=""> </font><br><font id="LD' + gNum + '" size=2 > </font></td>'); }
document.write('</tr>');
}
</script>
</tbody>
</table>
</td> </tr>
</table>
</form>
</div>
</div>
<script language="JavaScript">
//提交
function h_submit(){
if(hDays==""){
alert("没有选中任何日期!");
}
else{
alert(hDays);
}
}
//重置
function rebuild(){
$("#huiyi8 td").removeClass("selday").attr("on",0);
hDays=[];
}
</script>
<div id="details" style="margin-top: -1px;"></div>
</body> </html>
js文件
/*
*功能:带有节假日设置的万年历
*作者:王立岩
*时间:2013年8月6日
*/
var lunarInfo = new Array(
0x4bd8, 0x4ae0, 0xa570, 0x54d5, 0xd260, 0xd950, 0x5554, 0x56af, 0x9ad0, 0x55d2,
0x4ae0, 0xa5b6, 0xa4d0, 0xd250, 0xd255, 0xb54f, 0xd6a0, 0xada2, 0x95b0, 0x4977,
0x497f, 0xa4b0, 0xb4b5, 0x6a50, 0x6d40, 0xab54, 0x2b6f, 0x9570, 0x52f2, 0x4970,
0x6566, 0xd4a0, 0xea50, 0x6a95, 0x5adf, 0x2b60, 0x86e3, 0x92ef, 0xc8d7, 0xc95f,
0xd4a0, 0xd8a6, 0xb55f, 0x56a0, 0xa5b4, 0x25df, 0x92d0, 0xd2b2, 0xa950, 0xb557,
0x6ca0, 0xb550, 0x5355, 0x4daf, 0xa5b0, 0x4573, 0x52bf, 0xa9a8, 0xe950, 0x6aa0,
0xaea6, 0xab50, 0x4b60, 0xaae4, 0xa570, 0x5260, 0xf263, 0xd950, 0x5b57, 0x56a0,
0x96d0, 0x4dd5, 0x4ad0, 0xa4d0, 0xd4d4, 0xd250, 0xd558, 0xb540, 0xb6a0, 0x95a6,
0x95bf, 0x49b0, 0xa974, 0xa4b0, 0xb27a, 0x6a50, 0x6d40, 0xaf46, 0xab60, 0x9570,
0x4af5, 0x4970, 0x64b0, 0x74a3, 0xea50, 0x6b58, 0x5ac0, 0xab60, 0x96d5, 0x92e0,
0xc960, 0xd954, 0xd4a0, 0xda50, 0x7552, 0x56a0, 0xabb7, 0x25d0, 0x92d0, 0xcab5,
0xa950, 0xb4a0, 0xbaa4, 0xad50, 0x55d9, 0x4ba0, 0xa5b0, 0x5176, 0x52bf, 0xa930,
0x7954, 0x6aa0, 0xad50, 0x5b52, 0x4b60, 0xa6e6, 0xa4e0, 0xd260, 0xea65, 0xd530,
0x5aa0, 0x76a3, 0x96d0, 0x4afb, 0x4ad0, 0xa4d0, 0xd0b6, 0xd25f, 0xd520, 0xdd45,
0xb5a0, 0x56d0, 0x55b2, 0x49b0, 0xa577, 0xa4b0, 0xaa50, 0xb255, 0x6d2f, 0xada0,
0x4b63, 0x937f, 0x49f8, 0x4970, 0x64b0, 0x68a6, 0xea5f, 0x6b20, 0xa6c4, 0xaaef,
0x92e0, 0xd2e3, 0xc960, 0xd557, 0xd4a0, 0xda50, 0x5d55, 0x56a0, 0xa6d0, 0x55d4,
0x52d0, 0xa9b8, 0xa950, 0xb4a0, 0xb6a6, 0xad50, 0x55a0, 0xaba4, 0xa5b0, 0x52b0,
0xb273, 0x6930, 0x7337, 0x6aa0, 0xad50, 0x4b55, 0x4b6f, 0xa570, 0x54e4, 0xd260,
0xe968, 0xd520, 0xdaa0, 0x6aa6, 0x56df, 0x4ae0, 0xa9d4, 0xa4d0, 0xd150, 0xf252,
0xd520); var solarMonth = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
var Gan = new Array("甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸");
var Zhi = new Array("子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥");
var Animals = new Array("鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊", "猴", "鸡", "狗", "猪");
var solarTerm = new Array("小寒", "大寒", "立春", "雨水", "惊蛰", "春分", "清明", "谷雨", "立夏", "小满", "芒种", "夏至", "小暑", "大暑", "立秋", "处暑", "白露", "秋分", "寒露", "霜降", "立冬", "小雪", "大雪", "冬至")
var sTermInfo = new Array(0, 21208, 42467, 63836, 85337, 107014, 128867, 150921, 173149, 195551, 218072, 240693, 263343, 285989, 308563, 331033, 353350, 375494, 397447, 419210, 440795, 462224, 483532, 504758)
var nStr1 = new Array('日', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十')
var nStr2 = new Array('初', '十', '廿', '卅', ' ') var jcName0 = new Array('建', '除', '满', '平', '定', '执', '破', '危', '成', '收', '开', '闭');
var jcName1 = new Array('闭', '建', '除', '满', '平', '定', '执', '破', '危', '成', '收', '开');
var jcName2 = new Array('开', '闭', '建', '除', '满', '平', '定', '执', '破', '危', '成', '收');
var jcName3 = new Array('收', '开', '闭', '建', '除', '满', '平', '定', '执', '破', '危', '成');
var jcName4 = new Array('成', '收', '开', '闭', '建', '除', '满', '平', '定', '执', '破', '危');
var jcName5 = new Array('危', '成', '收', '开', '闭', '建', '除', '满', '平', '定', '执', '破');
var jcName6 = new Array('破', '危', '成', '收', '开', '闭', '建', '除', '满', '平', '定', '执');
var jcName7 = new Array('执', '破', '危', '成', '收', '开', '闭', '建', '除', '满', '平', '定');
var jcName8 = new Array('定', '执', '破', '危', '成', '收', '开', '闭', '建', '除', '满', '平');
var jcName9 = new Array('平', '定', '执', '破', '危', '成', '收', '开', '闭', '建', '除', '满');
var jcName10 = new Array('满', '平', '定', '执', '破', '危', '成', '收', '开', '闭', '建', '除');
var jcName11 = new Array('除', '满', '平', '定', '执', '破', '危', '成', '收', '开', '闭', '建'); function jcr(d) {
var jcrjx;
if (d == '建') jcrjx = '<span style="vertical-align:middle; margin:1px; font-size:12px"><img src="data:images/yi.gif"/></span> 出行.上任.会友.上书.见工<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 动土.开仓.嫁娶.纳采';
if (d == '除') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 除服.疗病.出行.拆卸.入宅<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 求官.上任.开张.搬家.探病';
if (d == '满') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祈福.祭祀.结亲.开市.交易<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 服药.求医.栽种.动土.迁移';
if (d == '平') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祭祀.修填.涂泥.余事勿取<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 移徙.入宅.嫁娶.开市.安葬';
if (d == '定') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 易.立券.会友.签约.纳畜<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 种植.置业.卖田.掘井.造船';
if (d == '执') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祈福.祭祀.求子.结婚.立约<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 开市.交易.搬家.远行';
if (d == '破') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 求医.赴考.祭祀.余事勿取<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 动土.出行.移徙.开市.修造';
if (d == '危') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 经营.交易.求官.纳畜.动土<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 登高.行船.安床.入宅.博彩';
if (d == '成') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祈福.入学.开市.求医.成服<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 词讼.安门.移徙';
if (d == '收') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祭祀.求财.签约.嫁娶.订盟<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 开市.安床.安葬.入宅.破土';
if (d == '开') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 疗病.结婚.交易.入仓.求职<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 安葬.动土.针灸';
if (d == '闭') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="data:images/yi.gif"/></span> 祭祀.交易.收财.安葬<br><br><span style="vertical-align:middle; margin:1px;"><img src="data:images/ji.gif"/></span> 宴会.安床.出行.嫁娶.移徙';
return(jcrjx);
} //国历节日 *表示放假日
var sFtv = new Array(
"0101*元旦",
"0106 中国13亿人口日",
"0110 中国110宣传日", "0202 世界湿地日",
"0204 世界抗癌症日",
"0210 世界气象日",
"0214 情人节",
"0221 国际母语日",
"0207 国际声援南非日", "0303 全国爱耳日",
"0308 妇女节",
"0312 植树节 孙中山逝世纪念日",
"0315 消费者权益保护日",
"0321 世界森林日",
"0322 世界水日",
"0323 世界气象日",
"0324 世界防治结核病日", "0401 愚人节",
"0407 世界卫生日",
"0422 世界地球日", "0501*国际劳动节",
"0504 中国青年节",
"0505 全国碘缺乏病日",
"0508 世界红十字日",
"0512 国际护士节",
"0515 国际家庭日",
"0517 世界电信日",
"0518 国际博物馆日",
"0519 中国汶川地震哀悼日 全国助残日",
"0520 全国学生营养日",
"0522 国际生物多样性日",
"0523 国际牛奶日",
"0531 世界无烟日", "0601 国际儿童节",
"0605 世界环境日",
"0606 全国爱眼日",
"0617 防治荒漠化和干旱日",
"0623 国际奥林匹克日",
"0625 全国土地日",
"0626 国际反毒品日", "0701 建党节 香港回归纪念日",
"0707 抗日战争纪念日",
"0711 世界人口日", "0801 八一建军节",
"0815 日本正式宣布无条件投降日", "0908 国际扫盲日",
"0909 毛主席逝世纪念日",
"0910 教师节",
"0916 国际臭氧层保护日",
"0917 国际和平日",
"0918 九·一八事变纪念日",
"0920 国际爱牙日",
"0927 世界旅游日",
"0928 孔子诞辰", "1001*国庆节 国际音乐节 国际老人节",
"1002 国际减轻自然灾害日",
"1004 世界动物日",
"1007 国际住房日",
"1008 世界视觉日 全国高血压日",
"1009 世界邮政日",
"1010 辛亥革命纪念日 世界精神卫生日",
"1015 国际盲人节",
"1016 世界粮食节",
"1017 世界消除贫困日",
"1022 世界传统医药日",
"1024 联合国日",
"1025 人类天花绝迹日",
"1026 足球诞生日",
"1031 万圣节", "1107 十月社会主义革命纪念日",
"1108 中国记者日",
"1109 消防宣传日",
"1110 世界青年节",
"1112 孙中山诞辰",
"1114 世界糖尿病日",
"1117 国际大学生节", "1201 世界艾滋病日",
"1203 世界残疾人日",
"1209 世界足球日",
"1210 世界人权日",
"1212 西安事变纪念日",
"1213 南京大屠杀",
"1220 澳门回归纪念日",
"1221 国际篮球日",
"1224 平安夜",
"1225 圣诞节 世界强化免疫日",
"1226 毛主席诞辰")
//农历节日 *表示放假日
var lFtv = new Array(
"0101*春节",
"0102*大年初二",
"0103*大年初三",
"0104*大年初四",
"0105*大年初五",
"0106*大年初六",
"0107*大年初七",
"0105 路神生日",
"0115 元宵节",
"0202 龙抬头",
"0219 观世音圣诞",
"0404 寒食节",
"0408 佛诞节 ",
"0505*端午节",
"0606 天贶节 姑姑节",
"0624 彝族火把节",
"0707 七夕情人节",
"0714 鬼节(南方)",
"0715 盂兰节",
"0730 地藏节",
"0815*中秋节",
"0909 重阳节",
"1001 祭祖节",
"1117 阿弥陀佛圣诞",
"1208 腊八节 释迦如来成道日",
"1223 过小年",
"1229*腊月二十九",
"0100*除夕");
//某月的第几个星期几; 5,6,7,8 表示到数第 1,2,3,4 个星期几
var wFtv = new Array(
"0110 黑人节",
"0150 世界麻风日",
"0121 日本成人节",
"0520 母亲节",
"0530 全国助残日",
"0630 父亲节",
"0716 合作节",
"0730 被奴役国家周",
"0932 国际和平日",
"0940 国际聋人节 世界儿童日",
"1011 国际住房日",
"1144 感恩节") /*****************************************************************************
日期计算
*****************************************************************************/ //====================================== 返回农历 y年的总天数
function lYearDays(y) {
var i, sum = 348;
for (i = 0x8000; i > 0x8; i >>= 1) sum += (lunarInfo[y - 1900] & i) ? 1 : 0;
return(sum + leapDays(y));
} //====================================== 返回农历 y年闰月的天数
function leapDays(y) {
if (leapMonth(y)) return( (lunarInfo[y - 1899] & 0xf) == 0xf ? 30 : 29);
else return(0);
} //====================================== 返回农历 y年闰哪个月 1-12 , 没闰返回 0
function leapMonth(y) {
var lm = lunarInfo[y - 1900] & 0xf;
return(lm == 0xf ? 0 : lm);
} //====================================== 返回农历 y年m月的总天数
function monthDays(y, m) {
return( (lunarInfo[y - 1900] & (0x10000 >> m)) ? 30 : 29 );
} //====================================== 算出农历, 传入日期控件, 返回农历日期控件
// 该控件属性有 .year .month .day .isLeap
function Lunar(objDate) { var i, leap = 0, temp = 0;
var offset = (Date.UTC(objDate.getFullYear(), objDate.getMonth(), objDate.getDate()) - Date.UTC(1900, 0, 31)) / 86400000; for (i = 1900; i < 2100 && offset > 0; i++) {
temp = lYearDays(i);
offset -= temp;
} if (offset < 0) {
offset += temp;
i--;
} this.year = i; leap = leapMonth(i); //闰哪个月
this.isLeap = false; for (i = 1; i < 13 && offset > 0; i++) {
//闰月
if (leap > 0 && i == (leap + 1) && this.isLeap == false) {
--i;
this.isLeap = true;
temp = leapDays(this.year);
}
else {
temp = monthDays(this.year, i);
} //解除闰月
if (this.isLeap == true && i == (leap + 1)) this.isLeap = false; offset -= temp;
} if (offset == 0 && leap > 0 && i == leap + 1)
if (this.isLeap) {
this.isLeap = false;
}
else {
this.isLeap = true;
--i;
} if (offset < 0) {
offset += temp;
--i;
} this.month = i;
this.day = offset + 1;
} //==============================返回公历 y年某m+1月的天数
function solarDays(y, m) {
if (m == 1)
return(((y % 4 == 0) && (y % 100 != 0) || (y % 400 == 0)) ? 29 : 28);
else
return(solarMonth[m]);
}
//============================== 传入 offset 返回干支, 0=甲子
function cyclical(num) {
return(Gan[num % 10] + Zhi[num % 12]);
} //============================== 阴历属性
function calElement(sYear, sMonth, sDay, week, lYear, lMonth, lDay, isLeap, cYear, cMonth, cDay) { this.isToday = false;
//瓣句
this.sYear = sYear; //公元年4位数字
this.sMonth = sMonth; //公元月数字
this.sDay = sDay; //公元日数字
this.week = week; //星期, 1个中文
//农历
this.lYear = lYear; //公元年4位数字
this.lMonth = lMonth; //农历月数字
this.lDay = lDay; //农历日数字
this.isLeap = isLeap; //是否为农历闰月?
//八字
this.cYear = cYear; //年柱, 2个中文
this.cMonth = cMonth; //月柱, 2个中文
this.cDay = cDay; //日柱, 2个中文 this.color = ''; this.lunarFestival = ''; //农历节日
this.solarFestival = ''; //公历节日
this.solarTerms = ''; //节气
} //===== 某年的第n个节气为几日(从0小寒起算)
function sTerm(y, n) {
var offDate = new Date(( 31556925974.7 * (y - 1900) + sTermInfo[n] * 60000 ) + Date.UTC(1900, 0, 6, 2, 5));
return(offDate.getUTCDate());
} //============================== 返回阴历 (y年,m+1月)
function cyclical6(num, num2) {
if (num == 0) return(jcName0[num2]);
if (num == 1) return(jcName1[num2]);
if (num == 2) return(jcName2[num2]);
if (num == 3) return(jcName3[num2]);
if (num == 4) return(jcName4[num2]);
if (num == 5) return(jcName5[num2]);
if (num == 6) return(jcName6[num2]);
if (num == 7) return(jcName7[num2]);
if (num == 8) return(jcName8[num2]);
if (num == 9) return(jcName9[num2]);
if (num == 10) return(jcName10[num2]);
if (num == 11) return(jcName11[num2]);
}
function CalConv2(yy, mm, dd, y, d, m, dt, nm, nd) {
var dy = d + '' + dd
if ((yy == 0 && dd == 6) || (yy == 6 && dd == 0) || (yy == 1 && dd == 7) || (yy == 7 && dd == 1) || (yy == 2 && dd == 8) || (yy == 8 && dd == 2) || (yy == 3 && dd == 9) || (yy == 9 && dd == 3) || (yy == 4 && dd == 10) || (yy == 10 && dd == 4) || (yy == 5 && dd == 11) || (yy == 11 && dd == 5)) {
return '<FONT color=#0000A0>日值岁破 大事不宜</font>';
}
else if ((mm == 0 && dd == 6) || (mm == 6 && dd == 0) || (mm == 1 && dd == 7) || (mm == 7 && dd == 1) || (mm == 2 && dd == 8) || (mm == 8 && dd == 2) || (mm == 3 && dd == 9) || (mm == 9 && dd == 3) || (mm == 4 && dd == 10) || (mm == 10 && dd == 4) || (mm == 5 && dd == 11) || (mm == 11 && dd == 5)) {
return '<FONT color=#0000A0>日值月破 大事不宜</font>';
}
else if ((y == 0 && dy == '911') || (y == 1 && dy == '55') || (y == 2 && dy == '111') || (y == 3 && dy == '75') || (y == 4 && dy == '311') || (y == 5 && dy == '95') || (y == 6 && dy == '511') || (y == 7 && dy == '15') || (y == 8 && dy == '711') || (y == 9 && dy == '35')) {
return '<FONT color=#0000A0>日值上朔 大事不宜</font>';
}
else if ((m == 1 && dt == 13) || (m == 2 && dt == 11) || (m == 3 && dt == 9) || (m == 4 && dt == 7) || (m == 5 && dt == 5) || (m == 6 && dt == 3) || (m == 7 && dt == 1) || (m == 7 && dt == 29) || (m == 8 && dt == 27) || (m == 9 && dt == 25) || (m == 10 && dt == 23) || (m == 11 && dt == 21) || (m == 12 && dt == 19)) {
return '<FONT color=#0000A0>日值杨公十三忌 大事不宜</font>';
}
else {
return 0;
}
} function calendar(y, m) { var sDObj, lDObj, lY, lM, lD = 1, lL, lX = 0, tmp1, tmp2, lM2,lY2,lD2,tmp3,dayglus,bsg,xs,xs1,fs,fs1,cs,cs1
var cY, cM, cD; //年柱,月柱,日柱
var lDPOS = new Array(3);
var n = 0;
var firstLM = 0; sDObj = new Date(y, m, 1, 0, 0, 0, 0); //当月一日日期 this.length = solarDays(y, m); //公历当月天数
this.firstWeek = sDObj.getDay(); //公历当月1日星期几 ////////年柱 1900年立春后为庚子年(60进制36)
if (m < 2) cY = cyclical(y - 1900 + 36 - 1);
else cY = cyclical(y - 1900 + 36);
var term2 = sTerm(y, 2); //立春日期 ////////月柱 1900年1月小寒以前为 丙子月(60进制12)
var firstNode = sTerm(y, m * 2) //返回当月「节」为几日开始
cM = cyclical((y - 1900) * 12 + m + 12); lM2 = (y - 1900) * 12 + m + 12;
//当月一日与 1900/1/1 相差天数
//1900/1/1与 1970/1/1 相差25567日, 1900/1/1 日柱为甲戌日(60进制10)
var dayCyclical = Date.UTC(y, m, 1, 0, 0, 0, 0) / 86400000 + 25567 + 10; for (var i = 0; i < this.length; i++) { if (lD > lX) {
sDObj = new Date(y, m, i + 1); //当月一日日期
lDObj = new Lunar(sDObj); //农历
lY = lDObj.year; //农历年
lM = lDObj.month; //农历月
lD = lDObj.day; //农历日
lL = lDObj.isLeap; //农历是否闰月
lX = lL ? leapDays(lY) : monthDays(lY, lM); //农历当月最后一天 if (n == 0) firstLM = lM;
lDPOS[n++] = i - lD + 1;
} //依节气调整二月分的年柱, 以立春为界
if (m == 1 && (i + 1) == term2) {
cY = cyclical(y - 1900 + 36);
lY2 = (y - 1900 + 36);
}
//依节气月柱, 以「节」为界
if ((i + 1) == firstNode) {
cM = cyclical((y - 1900) * 12 + m + 13);
lM2 = (y - 1900) * 12 + m + 13;
}
//日柱
cD = cyclical(dayCyclical + i);
lD2 = (dayCyclical + i); this[i] = new calElement(y, m + 1, i + 1, nStr1[(i + this.firstWeek) % 7],
lY, lM, lD++, lL,
cY, cM, cD); this[i].sgz5 = CalConv2(lY2 % 12, lM2 % 12, (lD2) % 12, lY2 % 10, (lD2) % 10, lM, lD - 1, m + 1, cs1);
this[i].sgz3 = cyclical6(lM2 % 12, (lD2) % 12); } //节气
tmp1 = sTerm(y, m * 2) - 1;
tmp2 = sTerm(y, m * 2 + 1) - 1;
this[tmp1].solarTerms = solarTerm[m * 2];
this[tmp2].solarTerms = solarTerm[m * 2 + 1];
if (m == 3) this[tmp1].color = ''; //清明颜色 //国历节日
for (i in sFtv)
if (sFtv[i].match(/^(\d{2})(\d{2})([\s\*])(.+)$/))
if (Number(RegExp.$1) == (m + 1)) {
this[Number(RegExp.$2) - 1].solarFestival += RegExp.$4 + ' '
if (RegExp.$3 == '*') this[Number(RegExp.$2) - 1].color = ''
} //农历节日
for (i in lFtv)
if (lFtv[i].match(/^(\d{2})(.{2})([\s\*])(.+)$/)) {
tmp1 = Number(RegExp.$1) - firstLM
if (tmp1 == -11) tmp1 = 1
if (tmp1 >= 0 && tmp1 < n) {
tmp2 = lDPOS[tmp1] + Number(RegExp.$2) - 1
if (tmp2 >= 0 && tmp2 < this.length) {
this[tmp2].lunarFestival += RegExp.$4 + ' '
if (RegExp.$3 == '*') this[tmp2].color = ''
}
}
} //复活节只出现在3或4月
if (m == 2 || m == 3) {
var estDay = new easter(y);
if (m == estDay.m)
this[estDay.d - 1].solarFestival = this[estDay.d - 1].solarFestival + ' 复活节(Easter Sunday)';
} //黑色星期五
if ((this.firstWeek + 12) % 7 == 5)
this[12].solarFestival += '黑色星期五'; //今日
if (y == tY && m == tM) this[tD - 1].isToday = true;
} //======================================= 返回该年的复活节(春分后第一次满月周后的第一主日)
function easter(y) { var term2 = sTerm(y, 5); //取得春分日期
var dayTerm2 = new Date(Date.UTC(y, 2, term2, 0, 0, 0, 0)); //取得春分的公历日期控件(春分一定出现在3月)
var lDayTerm2 = new Lunar(dayTerm2); //取得取得春分农历 if (lDayTerm2.day < 15) //取得下个月圆的相差天数
var lMlen = 15 - lDayTerm2.day;
else
var lMlen = (lDayTerm2.isLeap ? leapDays(y) : monthDays(y, lDayTerm2.month)) - lDayTerm2.day + 15; //一天等于 1000*60*60*24 = 86400000 毫秒
var l15 = new Date(dayTerm2.getTime() + 86400000 * lMlen); //求出第一次月圆为公历几日
var dayEaster = new Date(l15.getTime() + 86400000 * ( 7 - l15.getUTCDay() )); //求出下个周日 this.m = dayEaster.getUTCMonth();
this.d = dayEaster.getUTCDate(); }
//====================== 中文日期
function cDay(d) {
var s; switch (d) {
case 10:
s = '初十'; break;
case 20:
s = '二十'; break;
break;
case 30:
s = '三十'; break;
break;
default :
s = nStr2[Math.floor(d / 10)];
s += nStr1[d % 10];
}
return(s);
}
var cld; /*清除数据*/
function clear() {
console.log(1)
for (i = 0; i < 42; i++) {
sObj = $("#SD" + i)[0];
sObj.innerHTML = '';
lObj = $("#LD" + i)[0];
lObj.innerHTML = '';
$("#GD" + i).removeClass("unover");
$("#GD" + i).removeClass("jinri");
$("#GD" + i).removeClass("selday"); } } var Today = new Date();
var tY = Today.getFullYear();
var tM = Today.getMonth(); var tD = Today.getDate();
////////////////////////////////////////////////////////////////////////////// var width = "130";
var offsetX = 2;
var offsetY = 18; var x = 0;
var y = 0;
var snow = 0;
var sw = 0;
var cnt = 0;
var dStyle; // 将农历iLunarMonth月格式化成农历表示的字符串
function FormatLunarMonth(iLunarMonth) {
var szText = new String("正二三四五六七八九十");
var strMonth;
if (iLunarMonth <= 10) {
strMonth = szText.substr(iLunarMonth - 1, 1);
}
else if (iLunarMonth == 11) strMonth = "十一";
else strMonth = "十二";
return strMonth + "月";
}
// 将农历iLunarDay日格式化成农历表示的字符串
function FormatLunarDay(iLunarDay) {
var szText1 = new String("初十廿三");
var szText2 = new String("一二三四五六七八九十");
var strDay;
if ((iLunarDay != 20) && (iLunarDay != 30)) {
strDay = szText1.substr((iLunarDay - 1) / 10, 1) + szText2.substr((iLunarDay - 1) % 10, 1);
}
else if (iLunarDay != 20) {
strDay = szText1.substr(iLunarDay / 10, 1) + "十";
}
else {
strDay = "二十";
}
return strDay;
}
//显示详细日期资料
function mOvr(thisObj, v) {
var s,festival,jy; sObj = $("#SD" + v);
var d = sObj.html() - 1; if (sObj.html() != '') {
if (cld[d].sgz5 != 0) { jy = cld[d].sgz5;
} else {
jy = jcr(cld[d].sgz3); } var arr = [];
if (cld[d].solarTerms == '' && cld[d].solarFestival == '' && cld[d].lunarFestival == '') arr.push('<div id="teshu"></div>');
else
arr.push('<div id="teshu"><FONT COLOR="#ff0000" STYLE="font-size:12px;">' + cld[d].solarTerms + ' ' + cld[d].solarFestival + ' ' + cld[d].lunarFestival + '</FONT></div>'); arr.push('<div style="width:65px; height:30px; color:#666666; float:left; font-size:60px; text-align:center;">' + cld[d].sDay + '</div>');
arr.push('<font color="black" style="font-weight:bold;font-size:13px;"> ' + cld[d].sYear + '年' + cld[d].sMonth + '月' + cld[d].sDay + '日</font>');
arr.push('<font style="font-size:12px;line-height:28px"><b>' + '星期' + cld[d].week + '</b></font><br>');
arr.push('<font style="font-size:12px;color:#000000;" >农历' + (cld[d].isLeap ? '闰' : ' ') + FormatLunarMonth(cld[d].lMonth) + FormatLunarDay(cld[d].lDay) + '</font>');
arr.push('<font style="font-size:12px"> ' + cld[d].cYear + '年 ' + cld[d].cMonth + '月 ' + cld[d].cDay + '日</font><br><br>');
arr.push('<div style="width:95%; height:70px; margin-top:30px; padding-top:8px; border-top:1px solid #CCCCCC; margin-left:auto; margin-right:auto;">' + jy + '</div>'); //thisObj.style.backgroundColor = '#fbfbad';
var d = $(thisObj);
var pos = d.offset();
var t = pos.top + d.height() + 5; // 弹出框的上边位置
var l = pos.left + d.width() - 150; // 弹出框的左边位置 var winWidth = 0; var winHeight = 0; function findDimensions() { // 获取窗口宽度 if (window.innerWidth) winWidth = window.innerWidth; else if ((document.body) && (document.body.clientWidth)) winWidth = document.body.clientWidth; // 获取窗口高度 if (window.innerHeight) winHeight = window.innerHeight; else if ((document.body) && (document.body.clientHeight)) winHeight = document.body.clientHeight; // 通过深入 Document 内部对 body 进行检测,获取窗口大小 if (document.documentElement && document.documentElement.clientHeight && document.documentElement.clientWidth) { winHeight = document.documentElement.clientHeight; winWidth = document.documentElement.clientWidth; } // 结果输出至两个文本框 } findDimensions(); // 调用函数,获取数值 window.onresize = findDimensions; //-->
/* alert("h:"+winHeight+"w:"+winWidth)*/ if (winHeight - pos.top < 230) {
t = pos.top + d.height() - 180;
l = pos.left + d.width() + 5; } if (winWidth - pos.left < 350) { t = pos.top + d.height() - 180;
l = pos.left + d.width() - 360; if (pos.top < 216) {
t = pos.top + d.height() - 100;
l = pos.left + d.width() - 360;
}
} $("#details").addClass("pop");
$("#details").css({ "top": t, "left": l }).show();
$("#details").html(arr.join("")); if (snow == 0) { snow = 1; } }
}
//------王立岩------start------
//日期点击函数
function mOck(thisObj, v){
var onoff = thisObj.attributes["on"].value;
var dayContainer = thisObj.getElementsByTagName("font")[0];
//记录是否为周末
var lx='0';
var nian = $('#nian').text();
var yue = $('#yue').text();
var dayJson = "";
var day = dayContainer.innerHTML;
var dayColor = dayContainer.attributes["color"];
var dayF = nian+'/'+addZ(yue)+'/'+addZ(day);
if(dayColor&&dayColor.value=='red'&&getH(dayF)){
lx = '1';
}
dayJson = '{holiday:'+nian+addZ(yue)+addZ(day)+',lx:'+lx+'}';
}
//删除数组指定元素
function delArry(arr,obj){
for (var i = arr.length - 1; i > -1; i--) {
if (arr[i] == obj) {
arr.splice(i, 1);//参数(删除的元素下标,从该下标起删除几个元素)
}
}
}
//去重数组
function delMoreArry(){
var newArray = [],
temp = {};
for(var i = 0; i < this.length; i++){
temp[typeof(this[i])+this[i]] = this[i];
}
for(var j in temp){
newArray.push(temp[j]);
}
return newArray;
}
function addZ(obj){
return obj<10?'0'+obj:obj;
}
function getH(obj){
var d = new Date(Date.parse(obj));
var c=d.getDay();
if(c==0||c==6){
return true;
}else{
return false;
}
//switch(c){ case 0: a='星期日'; break; case 1: a='星期一'; break; case 2: a='星期二'; break; case 3: a='星期三'; case 4: a='星期四'; case 5: a='星期五'; case 6: a='星期六';}
}
//------王立岩------end---
//清除详细日期资料
function mOut(thisObj) { // thisObj.style.backgroundColor = '';
if (cnt >= 1) {
sw = 0
}
if (sw == 0) {
snow = 0;
document.getElementById("details").style.display = 'none';
}
else cnt++;
} /*初始化日期*/
var year;
var month;
var day;
$(function() { //使用同步ajax获取数据 ypr
$.ajax({
type:"post",
async:false,
//跳转路径
url:"/jeesite/a/ha01/haHyjhb/findHY", dataType: "json",
success:function(data){
var json=eval(data);
initRiliIndex();
clear();
$("#nian").html(tY);
$("#yue").html(tM + 1);
drawCld(tY, tM,json); }
}); /*年份递减*/
$("#nianjian").click(function() {
dateSelection.goPrevYear(); });
/*年份递加*/
$("#nianjia").click(function() {
dateSelection.goNextYear(); }); /*月份递减*/
$("#yuejian").click(function() {
dateSelection.goPrevMonth(); }); /*月份递加*/
$("#yuejia").click(function() {
dateSelection.goNextMonth();
}); }); //存放节假日
var hDays = [];
function drawCld(SY, SM,json) {
var i,sD,s,size,j=0;
cld = new calendar(SY, SM); $("#GZ")[0].innerHTML = ' 会议情况一览表'; //循环后台取到的json数据,获取年,月,日,进行判断
var datas =[];
for( j=0;j<json.length;j++){
var kssj = json[j].kssj;
var date= new Date(Date.parse(kssj.replace(/-/g, "/")));
year=date.getFullYear();
month = date.getMonth()+1;
day = date.getDate();
//判断 年,月 ,日是否相等
if(SY==year && SM+1==month && datas.indexOf(day) == -1){
datas.push(day);
}
}
for (i = 0; i < 42; i++) {
sObj = $("#SD" + i)[0];
lObj = $("#LD" + i)[0];
sObj.className = ''; sD = i - cld.firstWeek;
if (sD > -1 && sD < cld.length) { //日期内
var nowDay = sD+1;
var nowMon = SM+1; //如果日 相等,则标红并添加跳转链接
if(datas.indexOf(nowDay)!=-1){
sObj.innerHTML = '<a href="/jeesite/a/ha01/haHyjhb/findDateList?year='+SY+'&month='+nowMon+'&day='+nowDay+'" style="font-size:22px;" class="red">'+(sD + 1)+'</a>';
}else{
sObj.innerHTML = sD + 1;
} //wly 注册点击事件
$("#GD" + i).unbind('click').click(function(){mOck(this,sD + 1);});
var nowDays = SY+''+addZ((SM+1))+addZ((sD+1)); var hstr = hDays.join();
if(hstr.indexOf(nowDays)>-1){
$("#GD" + i).addClass("selday");
}
if (cld[sD].isToday) $("#GD" + i).addClass("jinri"); //今日颜色 sObj.style.color = cld[sD].color; //国定假日颜色 if (cld[sD].lDay == 1) //显示农历月
lObj.innerHTML = '<b>' + (cld[sD].isLeap ? '闰' : '') + cld[sD].lMonth + '月' + (monthDays(cld[sD].lYear, cld[sD].lMonth) == 29 ? '小' : '大') + '</b>';
else //显示农历日
lObj.innerHTML = cDay(cld[sD].lDay); s = cld[sD].lunarFestival;
if (s.length > 0) { //农历节日
if (s.length > 8) s = s.substr(0, 5) + '...';
s = s.fontcolor('');
}
else { //国历节日
s = cld[sD].solarFestival;
if (s.length > 0) {
if (s.length > 8) s = s.substr(0, 5) + '...';
s = (s == '黑色星期五') ? s.fontcolor('black') : s.fontcolor('#0066FF');
}
else { //廿四节气
s = cld[sD].solarTerms;
if (s.length > 0) s = s.fontcolor('limegreen');
}
}
if (cld[sD].solarTerms == '清明') s = '清明节'.fontcolor('');
if (cld[sD].solarTerms == '芒种') s = '芒种'.fontcolor('');
if (cld[sD].solarTerms == '夏至') s = '夏至'.fontcolor('');
if (cld[sD].solarTerms == '冬至') s = '冬至'.fontcolor(''); if (s.length > 0) lObj.innerHTML = s; }
else { //非日期
$("#GD" + i).addClass("unover"); }
} }
var global = {
currYear : -1, // 当前年
currMonth : -1, // 当前月,0-11
currDate : null, // 当前点选的日期
uid : null,
username : null,
email : null,
single : false
// 是否为独立页调用,如果是值为日历id,使用时请注意对0的判断,使用 single !== false 或者 single === false
}; var dateSelection = {
currYear : -1,
currMonth : -1, minYear : 1901,
maxYear : 2100, beginYear : 0,
endYear : 0, tmpYear : -1,
tmpMonth : -1, init : function(year, month) {
if (typeof year == 'undefined' || typeof month == 'undefined') {
year = global.currYear;
month = global.currMonth;
}
this.setYear(year);
this.setMonth(month);
this.showYearContent();
this.showMonthContent();
},
show : function() {
document.getElementById('dateSelectionDiv').style.display = 'block';
},
hide : function() {
this.rollback();
document.getElementById('dateSelectionDiv').style.display = 'none';
},
today : function() {
var today = new Date();
var year = today.getFullYear();
var month = today.getMonth(); if (this.currYear != year || this.currMonth != month) {
if (this.tmpYear == year && this.tmpMonth == month) {
this.rollback();
} else {
this.init(year, month);
this.commit();
}
}
},
go : function() {
if (this.currYear == this.tmpYear && this.currMonth == this.tmpMonth) {
this.rollback();
} else {
this.commit();
}
this.hide();
},
goToday : function() {
this.today();
this.hide();
},
goPrevMonth : function() {
this.prevMonth();
this.commit();
},
goNextMonth : function() {
this.nextMonth();
this.commit();
},
goPrevYear : function() {
this.prevYear();
this.commit();
},
goNextYear : function() {
this.nextYear();
this.commit();
},
changeView : function() {
global.currYear = this.currYear;
global.currMonth = this.currMonth;
clear();
$("#nian").html(global.currYear);
$("#yue").html(parseInt(global.currMonth) + 1); //如果执行点击事件,下一月,下一年,上一月,上一年,执行 ajax
$.ajax({
type:"post",
async:false,
//跳转路径
url:"/jeesite/a/ha01/haHyjhb/findHY", dataType: "json",
success:function(data){
var json=eval(data);
//initRiliIndex();
drawCld(global.currYear, global.currMonth,json);
}
}); },
commit : function() {
if (this.tmpYear != -1 || this.tmpMonth != -1) {
// 如果发生了变化
if (this.currYear != this.tmpYear
|| this.currMonth != this.tmpMonth) {
// 执行某操作
this.showYearContent();
this.showMonthContent();
this.changeView(); } this.tmpYear = -1;
this.tmpMonth = -1;
}
},
rollback : function() {
if (this.tmpYear != -1) {
this.setYear(this.tmpYear);
}
if (this.tmpMonth != -1) {
this.setMonth(this.tmpMonth);
}
this.tmpYear = -1;
this.tmpMonth = -1;
this.showYearContent();
this.showMonthContent();
},
prevMonth : function() {
var month = this.currMonth - 1;
if (month == -1) {
var year = this.currYear - 1;
if (year >= this.minYear) {
month = 11;
this.setYear(year);
} else {
month = 0;
}
}
this.setMonth(month);
},
nextMonth : function() {
var month = this.currMonth + 1;
if (month == 12) {
var year = this.currYear + 1;
if (year <= this.maxYear) {
month = 0;
this.setYear(year);
} else {
month = 11;
}
}
this.setMonth(month);
},
prevYear : function() {
var year = this.currYear - 1;
if (year >= this.minYear) {
this.setYear(year);
}
},
nextYear : function() {
var year = this.currYear + 1;
if (year <= this.maxYear) {
this.setYear(year);
}
},
prevYearPage : function() {
this.endYear = this.beginYear - 1;
this.showYearContent(null, this.endYear);
},
nextYearPage : function() {
this.beginYear = this.endYear + 1;
this.showYearContent(this.beginYear, null);
},
selectYear : function() {//杨:select
var selectY = $('select[@name="SY"] option[@selected]').text();
this.setYear(selectY);
this.commit();
},
selectMonth : function() {
var selectM = $('select[@name="SM"] option[@selected]').text();
this.setMonth(selectM - 1);
this.commit();
},
setYear : function(value) {
if (this.tmpYear == -1 && this.currYear != -1) {
this.tmpYear = this.currYear;
}
$('#SY' + this.currYear).removeClass('curr');
this.currYear = value;
$('#SY' + this.currYear).addClass('curr');
},
setMonth : function(value) {
if (this.tmpMonth == -1 && this.currMonth != -1) {
this.tmpMonth = this.currMonth;
}
$('#SM' + this.currMonth).removeClass('curr');
this.currMonth = value;
$('#SM' + this.currMonth).addClass('curr');
},
showYearContent : function(beginYear, endYear) {
if (!beginYear) {
if (!endYear) {
endYear = this.currYear + 1;
}
this.endYear = endYear;
if (this.endYear > this.maxYear) {
this.endYear = this.maxYear;
}
this.beginYear = this.endYear - 3;
if (this.beginYear < this.minYear) {
this.beginYear = this.minYear;
this.endYear = this.beginYear + 3;
}
}
if (!endYear) {
if (!beginYear) {
beginYear = this.currYear - 2;
}
this.beginYear = beginYear;
if (this.beginYear < this.minYear) {
this.beginYear = this.minYear;
}
this.endYear = this.beginYear + 3;
if (this.endYear > this.maxYear) {
this.endYear = this.maxYear;
this.beginYear = this.endYear - 3;
}
} var s = '';
for (var i = this.beginYear; i <= this.endYear; i++) {
s += '<span id="SY' + i
+ '" class="year" onclick="dateSelection.setYear(' + i
+ ')">' + i + '</span>';
}
document.getElementById('yearListContent').innerHTML = s;
$('#SY' + this.currYear).addClass('curr');
},
showMonthContent : function() {
var s = '';
for (var i = 0; i < 12; i++) {
s += '<span id="SM' + i
+ '" class="month" onclick="dateSelection.setMonth(' + i
+ ')">' + (i + 1).toString() + '</span>';
}
document.getElementById('monthListContent').innerHTML = s;
$('#SM' + this.currMonth).addClass('curr');
},
//根据节假日去相关的月份
goHoliday : function(N){
this.setMonth(N);
this.commit();
}
};
function initRiliIndex() {
var dateObj = new Date();
global.currYear = dateObj.getFullYear();
global.currMonth = dateObj.getMonth(); dateSelection.init(); }
后台方法
/*
* 异步查询数据,日期展示 ypr
*/
@ResponseBody
@RequestMapping(value = "findHY")
public String lianLr(HaHyjhb haHyjhb,HttpServletRequest request, HttpServletResponse response,Model model) throws IOException { List<HaHyjhb> list=haHyjhbService.findList(haHyjhb); ObjectMapper mapper= new ObjectMapper();
String jsonStr = mapper.writeValueAsString(list);
System.out.println(jsonStr ); return jsonStr;
} /*
* 根据年月日,进行模糊查询 会议信息
*/
@RequiresPermissions("ha01:haHyjhb:view")
@RequestMapping(value = "/findDateList")
public String findDateList(HaHyjhb haHyjhb, HttpServletRequest request, HttpServletResponse response, Model model,
String year,String month,String day) { String str = year+"-"+month+"-"+day; DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd");
Date date = null;
try {
date = format1.parse(str);
String strCurrentTime = format1.format(date); haHyjhb.setMc(strCurrentTime);
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
List<HaHyjhb> findDateLike = haHyjhbService.findDateLike(haHyjhb); Page<HaHyjhb> page = haHyjhbService.findPage(new Page<HaHyjhb>(request, response), haHyjhb); page.setList(findDateLike); model.addAttribute("page", page);
return "modules/ha/ha01/haHyjhbList";
}
sql
<!--
根据日期进行模糊查询 ypr
-->
<select id="findDateLike" resultType="HaHyjhb">
SELECT
*
FROM
ha_hyjhb AS t
WHERE
DATE_FORMAT(t.kssj, '%Y-%m-%d') LIKE #{mc}
</select>
再此记录下。
参考链接https://blog.csdn.net/niuyongaiai/article/details/52453377?locationNum=15
使用calendar日历插件实现动态展示会议信息的更多相关文章
- EasyUI Calendar 日历插件,只显示年月。
从别人的博客园搬过来的,放在这里只是为了方便自己用.已经注明原文出处,尊重别人的劳动成果. 原文地址:http://www.cnblogs.com/hmYao/p/5779463.html 此日历插件 ...
- EasyUI动态展示用户信息
业务需求:用户登录后展示用户名.用户对应的角色.EasyUI只不过是一个前端的框架,封装了一些组件和样式,你可以用jsp直接调后台获取到用户信息展示,但我这里想用html页面,用目前流行的说法:前后端 ...
- fullcalendar日历插件的使用并动态增删改查
我上个项目是做了一个关于教育方面的web端页面,其中的课程表就要用到fullcalendar日历插件,刚开始也是不会用,因为以前也没用过,后面也是看官方文档,问同事,最后完成了这个课程表,个人感觉fu ...
- XgCalendar日历插件动态添加参数
在使用xgcalendar日历插件的时候,参数数组并非只有类型.显示时间.时区等这些参数,还可以根据extParam自定义参数扩展搜索条件,例如根据用户Id搜索不同用户的日历信息,需要将用户的Id存在 ...
- 【UI插件】开发一个简单日历插件(上)
前言 最近开始整理我们的单页应用框架了,虽然可能比不上MVVM模式的开发效率,也可能没有Backbone框架模块清晰,但是好歹也是自己开发出来 而且也用于了这么多频道的东西,如果没有总结,没有整理,没 ...
- 给开发者准备的 10 款最好的 jQuery 日历插件[转]
这篇文章介绍的是 10 款最棒而且又很有用的 jQuery 日历插件,允许开发者们把这些漂亮的日历插件结合到自己的网站中.这些日历插件易用性都很强,轻轻松松的就可以把漂亮的日历插件装饰到你的网站了.希 ...
- Framework 7 日历插件改成Picker 模式
Framework 7 里面的日历插件默认的2种模式: 1.文本框 2.直接展示 如下图: 更多例子点这里 而我的需求如下图: 点击小图标再弹出日历,选择某个日期,隐藏日历弹层. 实现步骤: 1.写小 ...
- 被逼着写的jquery工作日管理日历插件
因为工作原因,在我刚进入新公司之后,立马要求让我做一个jquery的插件demo.我的天,我面试的可是.net工程师啊.虽然以前接触过js,jquery,但也只是接触过一丢丢啊,没办法,只好硬着头皮上 ...
- 日历插件FullCalendar应用:(二)数据增删改
接上一篇 日历插件FullCalendar应用:(一)数据展现. 这一篇主要讲使用fullcalendar插件如何做数据的增删改,用到了art.dialog web对话框组件,上一篇用到的webFor ...
随机推荐
- HTML+JS实现视频上传显示进度条
示例代码: css部分: #content{border: 1px solid saddlebrown;padding: 16px;border-radius: 2px} .list {top: 15 ...
- Hive 的collect_set使用详解
Hive 的collect_set使用详解 https://blog.csdn.net/liyantianmin/article/details/48262109 对于非group by字段,可以 ...
- 一次tomcat的调优记录
项目本身需要上传模型,使用的是springboot1.5.3. 上传的模型比较大,下载的过程中就出现了问题(下载是su调用的java接口,其开发并非本人负责,不可更改) 问题在于,下载的时候tomca ...
- 【js】Redux基本原理和使用
Redux不是说任何的应用都要用到它,如果遇到了react解决不了得问题,可以考虑使用它. 例如: 用户的使用方式复杂不同身份的用户有不同的使用方式(比如普通用户和管理员)多个用户之间可以协作与服务器 ...
- Java 常见BUG 整理
1.BigDecimal初始化double 2.Integer java对于-128到127之间的数,会进行缓存,这个范围的Integer对象是同一个! == 是ok,但是超出这个范围就不可以用 ...
- Linux用户和权限管理
用户:资源获取标识符,资源分配,安全权限模型的核心要素之一 密码:来实现用户认证 创建用户:useradd Username 生成的属性信息 /etc/passwd 用户名:密码:占位符:UID:GU ...
- windows 使用npm安装webpack 4.0以及配置问题的解决办法
输入cmd点击打开 输入node -v 出现nodejs版本号 输入npm -v 出现npm版本号则安装npm安装成功, 2.安装webpack 桌面新建一个webpack-test文件夹,点击进入文 ...
- spring定时任务注解@Scheduled的记录
spring 定时任务@Scheduled 转自https://www.cnblogs.com/0201zcr/p/5995779.html 1.配置文件 <?xml version=" ...
- Ubuntu18.04 设置wifi热点
(1)在终端输入 命令:nm-connection-editor (2)然后点击wifi网络进行配置即可:
- C语言编程练习 GPS数据处理
题目内容: NMEA-0183协议是为了在不同的GPS(全球定位系统)导航设备中建立统一的BTCM(海事无线电技术委员会)标准,由美国国家海洋电子协会(NMEA-The National Marine ...