聚合新闻服务
手机wap浏览
您现在的位置: 动易模板 >> 动易中心 >> 动易教程 >> 正文
注册登陆
建站服务
视动工坊
服务项目
建站流程
建站价目
成功作品
联系信息
联系信息
视动工坊:动易认证设计师
动易模板大赛连续两次获奖
现共完成动易模板100余个
热诚欢迎定制改制动易模板
Q Q: 363881827
手机: 13153001848
Tel: 0531-83711777
Mail: wsdjqwj2003@163.com
   
为动易留言增加日历功能
作者:佚名 文章来源:本站原创 点击数: 更新时间:2008-8-19 7:45:05

功能:点击相应时间,即可查到当日的留言。

演示页:http://ylauto.vicp.net/YLcn/guestbook/index.asp

如何实现?

1,

<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中通过该日历算法实现的具体代码
 
    '先判断是否指定了一个年份和月份,没有则根据当前的年和月份显示
    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='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个)则输出一个换行
        if i mod 7=0 then
            response.write( "</tr><tr align=center bgcolor=ffffff height=19>")
        end if
        i=i+1
    loop
%>
</table>

将以上代码保存为calendar.asp,放入到GuestBook目录下

2,修改PowerEasy.GuestBook.asp文件,找到

                If IsDate(Trim(Request("keyword"))) = False Then
                    FoundErr = True
                    ErrMsg = ErrMsg & "<li>" & XmlText("Guest", "ShowAllGuest/Err1", "输入的关键字不是有效日期!") & "</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", "输入的关键字不是有效日期!") & "</li>"
                    Exit Sub
                Else
                    If SystemDatabaseType = "SQL" Then
   '如果数据量不大,用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



3,在相应留言模板页加入

<iframe  src="calendar.asp" style="width:216px; height:210px;" scrolling="no" frameborder="0" allowTransparency="true"></iframe>

动易中心录入:alang    责任编辑:alangyuafeng929 
  • 下一个动易中心: 没有了
  • 评论主题:为动易留言增加日历功能(评论内容只代表网友观点)
    版权所有:copyright 2005-2008 动易模板NO.1 核心:PowerEasy SiteWeaver™ 6.6 备案:鲁ICP备05007599号
    电话:0531-83711777(晚间)手机:13153001848 QQ:363881827 群号:一群13022466(满)二群36354619