動(dòng)易教程:運(yùn)用日歷功能查看指定日期的留言_動(dòng)易Cms教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
在網(wǎng)站留言頁(yè)面上增加了一個(gè)日歷,如何實(shí)現(xiàn)點(diǎn)擊相應(yīng)時(shí)間,即可查到當(dāng)日的留言?
下面是實(shí)現(xiàn)方法:
1、將以下代碼保存為calendar.asp,放入到GuestBook目錄下
<style>
html,body{margin:5px 0px 0px 0px;height:100%;font-size:9pt}
td { font-family: "宋體"; font-size:9pt}
</style>
<table width="180" cellpadding="0" cellspacing="1" bgcolor="dddddd" align=center>
<%
'以下為ASP中通過該日歷算法實(shí)現(xiàn)的具體代碼
'先判斷是否指定了一個(gè)年份和月份,沒有則根據(jù)當(dāng)前的年和月份顯示
If Request("ReqDate")="" then
CurrentDate=Date
else
CurrentDate=Trim(Request("ReqDate"))
end if
pyear=year(CurrentDate)
pmonth=month(CurrentDate)
'以下的代碼生成日歷顯示的表格頭內(nèi)容
%>
<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中沒有獲取指定月共有多少天的函數(shù),因此我們需要通過其他算法來獲得,算法其實(shí)很簡(jiǎn)單,就是計(jì)算一下要顯示月份的1日至下個(gè)月的1日一共相差幾天
fromDate = FormatDateTime(month(CurrentDate) & "/1/" & year(CurrentDate))
toDate = FormatDateTime(DateAdd("m",1,fromDate))
'獲得要顯示月份的第一天為周幾
nunmonthstart=weekday(fromDate)-1
'獲得要顯示的1日至下個(gè)月的1日一共相差幾天(月份一共有多少天)
nunmonthend=DateDiff("d",fromDate,toDate)
'判斷顯示日歷需要用幾行表格來顯示(每行顯示7天)
if nunmonthstart nunmonthend<36 then
maxi=36
else
maxi=43
end if
'循環(huán)生成表格并顯示
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='Search.asp?Field=GuestTime&KindID=0&keyword=" &pyear& "-" & pmonth & "-" & iv & "' target=_parent>" & iv & "</a></td>")
else
response.write( "<td align=center><a href='Search.asp?Field=GuestTime&KindID=0&keyword=" &pyear& "-" & pmonth & "-" & iv & "' target=_parent>" & iv & "</a></td>")
end if
else
response.write( "<td> </td>")
end if
'如果能被7整除(每行顯示7個(gè))則輸出一個(gè)換行
if i mod 7=0 then
response.write( "</tr><tr align=center bgcolor=ffffff height=19>")
end if
i=i 1
loop
%>
</table>
html,body{margin:5px 0px 0px 0px;height:100%;font-size:9pt}
td { font-family: "宋體"; font-size:9pt}
</style>
<table width="180" cellpadding="0" cellspacing="1" bgcolor="dddddd" align=center>
<%
'以下為ASP中通過該日歷算法實(shí)現(xiàn)的具體代碼
'先判斷是否指定了一個(gè)年份和月份,沒有則根據(jù)當(dāng)前的年和月份顯示
If Request("ReqDate")="" then
CurrentDate=Date
else
CurrentDate=Trim(Request("ReqDate"))
end if
pyear=year(CurrentDate)
pmonth=month(CurrentDate)
'以下的代碼生成日歷顯示的表格頭內(nèi)容
%>
<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中沒有獲取指定月共有多少天的函數(shù),因此我們需要通過其他算法來獲得,算法其實(shí)很簡(jiǎn)單,就是計(jì)算一下要顯示月份的1日至下個(gè)月的1日一共相差幾天
fromDate = FormatDateTime(month(CurrentDate) & "/1/" & year(CurrentDate))
toDate = FormatDateTime(DateAdd("m",1,fromDate))
'獲得要顯示月份的第一天為周幾
nunmonthstart=weekday(fromDate)-1
'獲得要顯示的1日至下個(gè)月的1日一共相差幾天(月份一共有多少天)
nunmonthend=DateDiff("d",fromDate,toDate)
'判斷顯示日歷需要用幾行表格來顯示(每行顯示7天)
if nunmonthstart nunmonthend<36 then
maxi=36
else
maxi=43
end if
'循環(huán)生成表格并顯示
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='Search.asp?Field=GuestTime&KindID=0&keyword=" &pyear& "-" & pmonth & "-" & iv & "' target=_parent>" & iv & "</a></td>")
else
response.write( "<td align=center><a href='Search.asp?Field=GuestTime&KindID=0&keyword=" &pyear& "-" & pmonth & "-" & iv & "' target=_parent>" & iv & "</a></td>")
end if
else
response.write( "<td> </td>")
end if
'如果能被7整除(每行顯示7個(gè))則輸出一個(gè)換行
if i mod 7=0 then
response.write( "</tr><tr align=center bgcolor=ffffff height=19>")
end if
i=i 1
loop
%>
</table>
2、修改PowerEasy.GuestBook.asp文件
找到
If IsDate(Trim(Request("keyword"))) = False Then
FoundErr = True
ErrMsg = ErrMsg & "<li>" & XmlText("Guest", "ShowAllGuest/Err1", "輸入的關(guān)鍵字不是有效日期!") & "</li>"
Exit Sub
Else
If SystemDatabaseType = "SQL" Then
sqlGuest = sqlGuest & " and GuestDatetime = '" & Trim(Request("keyword")) & "' "
Else
sqlGuest = sqlGuest & " and GuestDatetime = #" & Trim(Request("keyword")) & "# "
End If
End If
FoundErr = True
ErrMsg = ErrMsg & "<li>" & XmlText("Guest", "ShowAllGuest/Err1", "輸入的關(guān)鍵字不是有效日期!") & "</li>"
Exit Sub
Else
If SystemDatabaseType = "SQL" Then
sqlGuest = sqlGuest & " and GuestDatetime = '" & Trim(Request("keyword")) & "' "
Else
sqlGuest = sqlGuest & " and GuestDatetime = #" & Trim(Request("keyword")) & "# "
End If
End If
-----------------------------------------------------------------------------------
改為
If IsDate(Trim(Request("keyword"))) = False Then
FoundErr = True
ErrMsg = ErrMsg & "<li>" & XmlText("Guest", "ShowAllGuest/Err1", "輸入的關(guān)鍵字不是有效日期!") & "</li>"
Exit Sub
Else
If SystemDatabaseType = "SQL" Then
'如果數(shù)據(jù)量不大,用datediff是可以的,否則影響性能就最好用>=和 <
' sqlGuest = sqlGuest & " and GuestDatetime = '" & Trim(Request("keyword")) & "' "
FoundErr = True
ErrMsg = ErrMsg & "<li>" & XmlText("Guest", "ShowAllGuest/Err1", "輸入的關(guān)鍵字不是有效日期!") & "</li>"
Exit Sub
Else
If SystemDatabaseType = "SQL" Then
'如果數(shù)據(jù)量不大,用datediff是可以的,否則影響性能就最好用>=和 <
' sqlGuest = sqlGuest & " and GuestDatetime = '" & Trim(Request("keyword")) & "' "
'sqlGuest = sqlGuest & " and GuestDatetime between '" & Trim(Request("keyword")) & " 00:00:00' and '" & Trim(Request("keyword")) & " 23:59:59' "
sqlGuest = sqlGuest & " and datediff(day,guestdatetime,'" & Trim(Request("keyword")) & "')=0 "
Else
'sqlGuest = sqlGuest & " and GuestDatetime = #" & Trim(Request("keyword")) & "# "
sqlGuest = sqlGuest & " and GuestDatetime between #" & Trim(Request("keyword")) & " 00:00:00# and #" & Trim(Request("keyword")) & " 23:59:59# "
'sqlGuest = sqlGuest & " and datediff(day,guestdatetime,'" & Trim(Request("keyword")) & "')=0 "
End If
End If
sqlGuest = sqlGuest & " and datediff(day,guestdatetime,'" & Trim(Request("keyword")) & "')=0 "
Else
'sqlGuest = sqlGuest & " and GuestDatetime = #" & Trim(Request("keyword")) & "# "
sqlGuest = sqlGuest & " and GuestDatetime between #" & Trim(Request("keyword")) & " 00:00:00# and #" & Trim(Request("keyword")) & " 23:59:59# "
'sqlGuest = sqlGuest & " and datediff(day,guestdatetime,'" & Trim(Request("keyword")) & "')=0 "
End If
End If
3、在相應(yīng)留言模板頁(yè)加入
<iframe src="calendar.asp" style="width:216px; height:210px;" scrolling="no" frameborder="0" allowTransparency="true"></iframe>
效果圖:

相關(guān)動(dòng)易Cms教程:
- MAC錯(cuò)誤的解決方法
- 如何屏蔽動(dòng)易后臺(tái)導(dǎo)航里的某個(gè)功能菜單?
- 動(dòng)易.NET版本留言自動(dòng)選定欄目方法
- 動(dòng)易SiteFactoty整合Discuz!NT3.0
- 在任意位置獲取根節(jié)點(diǎn)ID標(biāo)簽
- 如何開啟SiteWeaver6.8的支持,反對(duì)功能
- Windows 2008安裝動(dòng)易.NET系統(tǒng)之四----動(dòng)易系統(tǒng)安裝篇
- Windows 2008安裝動(dòng)易.NET系統(tǒng)之三----數(shù)據(jù)庫(kù)篇
- Windows 2008安裝動(dòng)易.NET系統(tǒng)之二----IIS、目錄環(huán)境配置篇
- 數(shù)據(jù)庫(kù)修復(fù),SQL Server 2005內(nèi)部操作不一致的處理
- 如何安裝動(dòng)易.net程序權(quán)限配置
- 為什么提示對(duì)Windows系統(tǒng)文件夾下的Temp目錄沒有訪問權(quán)限?
動(dòng)易Cms教程教程Rss訂閱Cms教程搜索
動(dòng)易Cms教程推薦
- 在線支付頁(yè)去掉空行的方法
- 快速制作模板
- 第一部分:SiteWeaver程序各目錄權(quán)限分配
- 升級(jí)動(dòng)易2006spXto2006sp6遇到的錯(cuò)誤(至少一個(gè)參數(shù)沒有被指定值)
- 如何填寫網(wǎng)站關(guān)鍵詞和網(wǎng)頁(yè)描述內(nèi)容?
- 動(dòng)易2005版生成HTML時(shí)比4.03慢多了,怎么辦?
- 為什么我設(shè)置用戶的按點(diǎn)數(shù)排行后,前臺(tái)顯示樣式不對(duì)?
- 簡(jiǎn)析自定義表單使用教程
- 為什么2005版系統(tǒng)在線人數(shù)統(tǒng)計(jì)總是顯示為0?
- 為什么訪問SQL版時(shí)出現(xiàn)對(duì)象名
- 相關(guān)鏈接:
- 教程說明:
動(dòng)易Cms教程-動(dòng)易教程:運(yùn)用日歷功能查看指定日期的留言
。