<p><style>td { font-family: "宋體"; font-size:9pt}</style><body bgcolor="eeeeee"><table cellpadding="0" cellspacing="1" bgcolor="dddddd" align=center><%'以下為ASP中通過該日曆算法實現的具體代碼</p><p>'先判斷是否指定了一個年份和月份,沒有則根據當前的年和月份顯示If Request("ReqDate")="" then CurrentDate=Date else CurrentDate=Trim(Request("ReqDate")) end if pyear=year(CurrentDate) pmonth=month(CurrentDate)</p><p>'以下的代碼生成日曆顯示的表格頭內容%> <tr align="LEFT" bgcolor="#dddddd"> <td align="center"> <input type="button" value="<<" onclick="JavaScript:location.href='?ReqDate=<%=DateAdd("m",-1,CurrentDate) %>'"></td> <td colspan="5" align="center"> <%=pyear%>年<%=pmonth%>月</td> <td align="center"> <input type="button" value=">>" onclick="JavaScript:location.href='?ReqDate=<%=DateAdd("m",1,CurrentDate)%>'"></td> </tr> <tr align="center" bgcolor="#CCCCCC"> <td>日</td> <td>一</td> <td>二</td> <td>三</td> <td>四</td> <td>五</td> <td>六</td> </tr> <tr align=center bgcolor=ffffff height=19> <% '由於ASP中沒有獲取指定月共有多少天的函數,因此我們需要通過其他算法來獲得,算法其實很簡單,就是計算一下要顯示月份的1日至下個月的1日一共相差幾天fromDate = FormatDateTime(month(CurrentDate) & "/1/" & year(CurrentDate)) toDate = FormatDateTime(DateAdd("m",1,fromDate)) '獲得要顯示月份的第一天為周幾nunmonthstart=weekday(fromDate)-1 '獲得要顯示的1日至下個月的1日一共相差幾天(月份一共有多少天) nunmonthend=DateDiff("d",fromDate,toDate) '判斷顯示日曆需要用幾行表格來顯示(每行顯示7天) if nunmonthstart+nunmonthend<36 then maxi=36 else maxi=43 end if '循環生成表格並顯示i=1 do while i<maxi iv=i-nunmonthstart if i>nunmonthstart and i<=nunmonthend+nunmonthstart then '如果為顯示的是今天則用紅色背景顯示if iv=Day(now) and month(now)=pmonth and year(now)=pyear then response.write( "<td align=center bgcolor=ffaaaa>" & iv & "</td>") else response.write( "<td align=center>" & iv & "</td>") end if else response.write( "<td></td>") end if</p><p> '如果能被7整除(每行顯示7個)則輸出一個換行if i mod 7=0 then response.write( "</tr><tr align=center bgcolor=ffffff height=19>") end if i=i+1 loop%></table></body> [Ctrl+A 全選注:如需引入外部Js需刷新才能執行]