0

我有一个中继器,它创建一个按完成日期排序的任务列表。

           <asp:Repeater ID="rptCompletedProjectTasks" OnItemDataBound="rptCompletedProjectTasks_ItemDataBound" runat="server">
               <HeaderTemplate>
                   <h3>Completed Tasks</h3> 
                    <table class="projTaskTable">
                        <tr>
                            <th style="width:100px">W/C</th>
                            <th style="width:450px">Description</th>
                            <th style="width:100px">Due</th>
                            <th style="width:100px">Completed</th>
                            <th style="width:50px">Var</th>
                        </tr>
                    </HeaderTemplate>
                <ItemTemplate>
                    <tr>
                        <td><asp:Label ID="lblWeek" runat="server" Text=''></asp:Label></td>
                        <td><%# Eval("description") %></td>
                        <td><%# Eval("deadline", "{0:d MMM yy}") %></td>
                        <td><asp:Label ID="lblCompleted" runat="server" Text='<%# Eval("completedDate", "{0:d MMM yy}") %>'></asp:Label></td>
                        <td><%# Eval("var") %></td>
                   </tr>
                </ItemTemplate>
               <FooterTemplate></table></FooterTemplate>
            </asp:Repeater>

我想按周对已完成的任务进行可视化分组,一周开始日期在一组任务的第一行的左列中,而在一周发生变化之前,其他任何内容都没有。IE

在此处输入图像描述

我正在尝试检查上一项的 WeekCommencing 值,并且仅在 lblWeek 控件与使用 OnItemDataBound 的上一行的值不同时才更新它:

protected void rptCompletedProjectTasks_ItemDataBound(object sender, RepeaterItemEventArgs e)
        {
            DateTime weekCommencing = new DateTime(1970, 1, 1);


            if ((e.Item.ItemType != ListItemType.Header) && (e.Item.ItemType != ListItemType.Footer))
            {

                Label completedDate = e.Item.FindControl("lblCompleted") as Label;
                Label lblWeekCommencing = e.Item.FindControl("lblWeek") as Label;


                DateTime completed = Convert.ToDateTime(completedDate.Text);

                if (completed != weekCommencing)
                {

                    lblWeekCommencing.Text = getWeekCommencing(completed).ToString("d MMM");

                }
                else
                {
                    lblWeekCommencing.Text = "";
                }
                weekCommencing = completed;
            }

我用来获取一周开始日期的函数是:

protected DateTime getWeekCommencing(DateTime date)
        {

            int delta = DayOfWeek.Monday - date.DayOfWeek;
            DateTime monday = date.AddDays(delta);
            return monday;

        }
4

2 回答 2

1

也许您可以使用并检查这是 lastItem 吗?

e.Item.ItemIndex
于 2013-03-03T10:43:11.510 回答
1

实现此目的的一种简单方法是在页面类上使用私有属性。您可以创建一个属性,private DateTime currentWeek.并且您可以在页面加载中启动此属性,就像您在使用 weekCommencing 的方法开始时所做的那样。

比在每行数据绑定上,您可以检查此行日期是否与 currentWeek 变量在同一周,如果不是,则设置标签文本并将 currentWeek 设置为此行周。

protected void Page_Load(object sender, EventArgs e)
{
    currentWeek = new DateTime(1970, 1, 1);
}
于 2013-03-03T10:45:39.453 回答