在asp.net mvc中显示带有自定义超链接的日历年

时间:2009-04-19 06:57:46

标签: asp.net-mvc

我希望创建一个MVC网页,以日历格式显示一年中的12个月。在这个月的每一天,我只会加粗有任何活动的日期(来自数据库的数据)。带活动的日期也会链接到像/ Activity / 2008/12/25这样的路线

我即将尝试尝试asp.net ajax控件工具包日历控件,但想知道是否有其他人有任何建议。

1 个答案:

答案 0 :(得分:6)

渲染日历并不是非常复杂。通过在System.Globalization和DateTime中使用DateTimeFormatInfo,可以检索所有必要的信息:

  • DateTimeFormatInfo.CurrentInfo.FirstDayOfWeek
  • DateTimeFormatInfo.CurrentInfo.GetMonthName(月)
  • DateTimeFormatInfo.CurrentInfo.GetAbbreviatedDayName((星期几)dayNumber)

日历中的一个月可以在表格中呈现:

_ _ _ 1 2 3 4 
5 6 7 8 9 ...

开始时可以使用这样的空单元格数:

DateTime date = new DateTime(year, month, 1);
int emptyCells = ((int)date.DayOfWeek + 7 
    - (int)DateTimeFormatInfo.CurrentInfo.FirstDayOfWeek) % 7;

由于一个月内最多31天,开始时最多6个空单元格,因此最大Ceil(37/7)= 6行可以呈现一个月。因此,一个月内最多可​​以渲染42个单元格,其中一些将是空的。

每个7(一周中的天数)单元格在表格中插入一个新行。

int days = DateTime.DaysInMonth(year, month);
for (int i = 0; i != 42; i++)
{
    if (i % 7 == 0) {
        writer.WriteLine("<tr>");
        if( i > 0 ) writer.WriteLine("</tr>");
    }

    if (i < emptyCells || i >= emptyCells + days) {
        writer.WriteLine("<td class=\"cal-empty\">&nbsp;</td>");
    } else {
        writer.WriteLine("<td class=\"cal-day\"\">" + date.Day + "</td>");
        date = date.AddDays(1);
    }
}

此外,只需在日期为活动时,将非空单元格中的其他链接添加到所需路线。