ASP中通過該日曆演算法實現的具體代碼

來源:互聯網
上載者:User

複製代碼 代碼如下:<style>
td { font-family: "宋體"; font-size:9pt}
</style>
<body bgcolor="eeeeee">
<table width="180" cellpadding="0" cellspacing="1" bgcolor="dddddd" align=center>
<%
'以下為ASP中通過該日曆演算法實現的具體代碼

'先判斷是否指定了一個年份和月份,沒有則根據當前的年和月份顯示
If Request("ReqDate")="" then
CurrentDate=Date
else
CurrentDate=Trim(Request("ReqDate"))
end if
pyear=year(CurrentDate)
pmonth=month(CurrentDate)

'以下的代碼產生日曆顯示的表格頭內容
%>
<tr align="LEFT" bgcolor="#dddddd">
<td width="14%" height="19" 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 width="14%" align="center">
<input type="button" value=">>" onclick="JavaScript:location.href='?ReqDate=<%=DateAdd("m",1,CurrentDate)%>'">
</td>
</tr>
<tr align="center" bgcolor="#CCCCCC">
<td width="14%" height="19"> 日</td>
<td width="14%"> 一</td>
<td width="14%"> 二</td>
<td width="14%"> 三</td>
<td width="14%"> 四</td>
<td width="14%"> 五</td>
<td width="14%"> 六</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><a href='#' target=_blank>" & iv & "</a></td>")
else
response.write( "<td align=center><a href='#' target=_blank>" & iv & "</a></td>")
end if
else
response.write( "<td> </td>")
end if

'如果能被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></html>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.