一个关于日历的例子,里面的javascript代码我觉得没什么作用但是去掉后程序运行又有点小问题(月份默认为一月改也改不掉)。我把程序贴出来大侠们看看,给我说说里面的作用机理吧!
<%@ page language="java" import="java.util.*" %>
<%!
String year;
String month;
%>
<%
month=request.getParameter("month");
year =request.getParameter("year");
%>
<html>
<head>
<%@ page contentType="text/html;charset=GB2312" %>
<title>一个日历的例子 </title>
<script Language="JavaScript">
<!--
function changeMonth()
{
var mm="02_38.jsp?month="+document.sm.elements[0].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); //设定星期天为一个星期的第一天
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>
<center>
<form name="sm" method="post" action="02_38.jsp">
<h3>
<%=year%>年
<%=Integer.parseInt(month)+1%>月 <%--这二个重要数据都是从java脚本中来的!绝对不可能来自本表单,这一点很重要!--%>
</h3>
<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" onChange="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>
</center>
</body>
</html>