<%@ page contentType="text/html;charSet=gb2312" import="java.util.*" %>
<%!
String year;
String month;
%>
<%
month=request.getParameter("month");
year =request.getParameter("year");
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>日历</title>
<!-- 下面是处理onchange事件的JavaScript代码 -->
<script Language="JavaScript">
function changeMonth()
{
var mm = "calendar.jsp?month=" + document.sm.month.options.selectedIndex
+ "&year=" + <%=year%>;
window.open(mm,"_self");
}
</script>
</head>
<%! String days[]; %>
<%
days=new String[42];
for(int i=0;i<42;i++)
days[i]="";
%>
<%
//默认为当天
Calendar thisMonth=Calendar.getInstance();
//如果有参数传入,重新设置月份和年份
if(month!=null&&(!month.equals("null")))
thisMonth.set(Calendar.MONTH, Integer.parseInt(month) );
if(year!=null&&(!year.equals("null")))
thisMonth.set(Calendar.YEAR, Integer.parseInt(year) );
//重新获取年份和月份值
year=String.valueOf(thisMonth.get(Calendar.YEAR));
month=String.valueOf(thisMonth.get(Calendar.MONTH));
//将每周的第一天设置为星期天
thisMonth.setFirstDayOfWeek(Calendar.SUNDAY);
//每个月的第一天标记为1
thisMonth.set(Calendar.DAY_OF_MONTH,1);
//求这个月的第一天是星期几
int firstIndex=thisMonth.get(Calendar.DAY_OF_WEEK)-1;
//求这个月的天数
int maxIndex=thisMonth.getActualMaximum(Calendar.DAY_OF_MONTH);
for(int i=0;i<maxIndex;i++)
days[firstIndex+i]=String.valueOf(i+1);
%>
<body>
<FORM name="sm" method="POST" action="calendar.jsp">
<%=year%>年 <%=Integer.parseInt(month)+1%>月
<!-- 将日历显示在表格中 -->
<table border="0" width="168" height="81">
<div align=center>
<tr>
<th width="25" height="16" bgcolor="#FFFF00"><font color="red">日</font>
</th>
<th width="25" height="16" bgcolor="#FFFF00">一</th>
<th width="25" height="16" bgcolor="#FFFF00">二</th>
<th width="25" height="16" bgcolor="#FFFF00">三</th>
<th width="25" height="16" bgcolor="#FFFF00">四</th>
<th width="25" height="16" bgcolor="#FFFF00">五</th>
<th width="25" height="16" bgcolor="#FFFF00"><font color="green">六</font></th>
</tr>
<% for(int j=0;j<6;j++) { %>
<tr>
<% for(int i=j*7;i<(j+1)*7;i++) { %>
<td width="15%" height="16" bgcolor="#C0C0C0" valign="middle" align="center">
<%=days[i]%></td>
<% } %>
</tr>
<% } %>
</div>
</table>
<table border="0" width="168" height="20">
<tr>
<td width=30%>
<!-- 提供一个下拉列表供用户选择 -->
<select name="month" size="1" οnchange="changeMonth()" >
<option value="0">一月</option>
<option value="1">二月</option>
<option value="2">三月</option>
<option value="3">四月</option>
<option value="4">五月</option>
<option value="5">六月</option>
<option value="6">七月</option>
<option value="7">八月</option>
<option value="8">九月</option>
<option value="9">十月</option>
<option value="10">十一月</option>
<option value="11">十二月</option>
</select></td>
<td width=28%><input type=text name="year" value=<%=year%> size=4 maxlength=4></td>
<td>年</td>
<td width=28%><input type=submit value="提交"></td>
</tr>
</table>
</form>
<script Language="JavaScript">
document.sm.month.options.selectedIndex=<%=month%>;
</script>
</body>
</html>
转载于:https://www.cnblogs.com/IT-WJ/archive/2013/03/28/2986376.html