查看: 1657|回复: 0

[.NET源码] asp.net基于Calendar实现blog日历功能示例

发表于 2018-1-1 08:00:00

本文实例讲述了asp.net基于Calendar实现blog日历功能。分享给大家供大家参考,具体如下:

怎样用.net的Calendar控件来实现blog中站点日历的效果呢,我们知道站点日历最重要的功能就是,显现在哪天blog主人写了日志,点击日期,你将进入所选日期的日志列表,

首先,我们知道.net中的服务器控件是会进行Postback的,Calendar控件中的第一天在点击时,就会进行一次postback我们要做的就是改变它默认的链接,使它不触发postback事件,其次,就是要知道哪一天有没有日志。至于有没有日志,就要去数据库查询了。

在Calendar中有一个DayRender事件,该事件在呈现每一天时触发,我们可以从这里入手,首先定义一个数组变量:

  1. private int[] arrCurrentDays, arrPreDays, arrNextDays; //三个变量分别是当前月,前一月,和下一个月
  2. private int intCurrentMonth, intPreMonth, intNextMonth; //三个整型数组存放相对月份写有blog的日期
复制代码

然后在Calendar的DayRender事件中写下如下代码:

  1. CalendarDay d = ((DayRenderEventArgs)e).Day;
  2. TableCell c = ((DayRenderEventArgs)e).Cell;
  3. // 初始化当前月有Blog的日期数组
  4. if (intPreMonth == 0)
  5. {
  6. intPreMonth = d.Date.Month; // 注意:日历控件初始化时我们得到的第一个月并不是当前月,而是前一个月的月份
  7. intCurrentMonth = intPreMonth + 1;
  8. if (intCurrentMonth > 12)
  9. intCurrentMonth = 1;
  10. intNextMonth = intCurrentMonth + 1;
  11. if (intNextMonth > 12)
  12. intNextMonth = 1;
  13. arrPreDays = getArrayDay(d.Date.Year, intPreMonth); //得到前一个月有blog的日期数组
  14. arrCurrentDays = getArrayDay(d.Date.Year, intCurrentMonth);//得到当月有blog的日期数组
  15. arrNextDays = getArrayDay(d.Date.Year, intNextMonth);//得到下个月有blog的日期数组
  16. }
  17. int j = 0;
  18. if (d.Date.Month.Equals(intPreMonth))
  19. {
  20. while (!arrPreDays[j].Equals(0))
  21. {
  22. if (d.Date.Day.Equals(arrPreDays[j]))
  23. {
  24. c.Controls.Clear();
  25. c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
  26. d.Date.Month + "&day=" + d.Date.Day + ">" + d.Date.Day + "</a>"));
  27. }
  28. j++;
  29. }
  30. }
  31. else if (d.Date.Month.Equals(intCurrentMonth))
  32. {
  33. while (!arrCurrentDays[j].Equals(0))
  34. {
  35. if (d.Date.Day.Equals(arrCurrentDays[j]))
  36. {
  37. c.Controls.Clear();
  38. c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
  39. d.Date.Month + "&day=" + d.Date.Day + " title=查看"+d.Date.Day+"日日志>" + d.Date.Day + "</a>"));
  40. }
  41. j++;
  42. }
  43. }
  44. else if (d.Date.Month.Equals(intNextMonth))
  45. {
  46. while (!arrNextDays[j].Equals(0))
  47. {
  48. if (d.Date.Day.Equals(arrNextDays[j]))
  49. {
  50. c.Controls.Clear();
  51. c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
  52. d.Date.Month + "&day=" + d.Date.Day + ">" + d.Date.Day + "</a>"));
  53. }
  54. j++;
  55. }
复制代码

在这里我们注意的是getArrayDay()方法是从数据库里查询当月是否有日志的方法,它返回的是一个数组,我写的内容如下:

  1. public int[] getArrayDay(int intYear, int intMonth)
  2. {
  3. int[] intArray = new int[31];
  4. //从数据库里选取符合要求的记录,将日期存入数组
  5. string strSql = "select data from test where year(data)=" + intYear +
  6. " and month(data)=" + intMonth;
  7. //调用DbHelperOleDb自定义类中的ExecuteReader方法,它返回的是一个OleDbDataReader型
  8. OleDbDataReader dr = dbAccess.DbHelperOleDb.ExecuteReader(strSql);
  9. int i = 0;
  10. while (dr.Read())
  11. {
  12. if (i == 0)
  13. {
  14. intArray[i] = Convert.ToDateTime(dr["data"].ToString()).Day;
  15. string a=Convert.ToString(intArray[i]);
  16. i++;
  17. }
  18. else if (Convert.ToDateTime(dr["data"].ToString()).Day != intArray[i - 1])
  19. {
  20. intArray[i] = Convert.ToDateTime(dr["data"].ToString()).Day;
  21. i++;
  22. }
  23. }
  24. return intArray;
  25. }
复制代码

ok ,这样就行了,我们运行一下就可以看到效果了..

PS:这里再为大家分享几款本站的在线日期工具供大家参考:

在线万年历日历:
http://tools.jb51.net/bianmin/wannianli

网页万年历日历:
http://tools.jb51.net/bianmin/webwannianli

在线万年历黄历flash版:
http://tools.jb51.net/bianmin/flashwnl

更多关于asp.net相关内容感兴趣的读者可查看本站专题:《asp.net操作json技巧总结》、《asp.net字符串操作技巧汇总》、《asp.net操作XML技巧总结》、《asp.net文件操作技巧汇总》、《asp.net ajax技巧总结专题》及《asp.net缓存操作技巧总结》。

希望本文所述对大家asp.net程序设计有所帮助。



回复

使用道具 举报