Привязка DataTable к повторителю - PullRequest
0 голосов
/ 21 сентября 2018

Я перепробовал каждую комбинацию статей в интернете, которые я могу найти, и в этот момент я выдернул свои волосы.Приведенный ниже код, по-видимому, даже не пытается связать данные. Когда строка «throw исключение» не закомментирована, она не выдает исключение.

Я попытался просто передать DataTable IEnumerable, а не datatable /datarows, но я получаю «DataBinding:« System.Data.DataTable »не содержит свойство с именем« dateCompleted ».»

Буду признателен за любую помощь ...

C #

protected void runReportForUser(Guid UserID)
    {
        pnCard.Visible = true;
        pnNoPoints.Visible = false;

        using (var db = new db())
        {
            // scorecard logic

            var u = userProfile.get(UserID);

            var t = db.Database.SqlQuery<DataTable>("exec ReturnEntities '" + u.userID + "'").FirstOrDefault();
            //rptEvents.DataSource = t.ToArray()[0];

            rptEvents.DataSource = t.Rows;
            //rptEvents.DataSource = t;   

            rptEvents.DataBind();

        }
    }


protected void rptEvents_ItemDataBound(object sender, RepeaterItemEventArgs e)
    {
        if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
        {
            //throw new Exception("Test")
            DataRow dr = (DataRow)e.Item.DataItem;

            ((Label)e.Item.FindControl("lblDate")).Text = dr[0].ToString();
            //((Label)e.Item.FindControl("lblDate")).Text = DataBinder.Eval(e.Item.DataItem, "dateCompleted").ToString();
            ((Label)e.Item.FindControl("lblCategory")).Text = dr[1].ToString();
            ((Label)e.Item.FindControl("lblName")).Text = dr[2].ToString();
            ((Label)e.Item.FindControl("lblPointsValue")).Text = dr[3].ToString();

        }
    }

ASPX:

 <table width="100%" cellpadding="0" cellspacing="0" border="0">
        <tr>
            <th>Date</th>
            <th>Category</th>
            <th>Points Earned</th>
        </tr>
        <asp:Repeater ID="rptEvents" runat="server" OnItemDataBound="rptEvents_ItemDataBound">
            <ItemTemplate>
                <tr id="trEvents" runat="server">
                    <td><asp:Label ID="lblDate" runat="server" /></td>
                    <td><asp:Label ID="lblCategory" runat="server" /></td>
                    <td><asp:Label ID="lblName" runat="server" /></td>
                    <td><asp:Label ID="lblPointsValue" runat="server" /></td>
                </tr>
            </ItemTemplate>
        </asp:Repeater>
    </table>

1 Ответ

0 голосов
/ 21 сентября 2018

Я смог понять это после множества попыток разных вещей.В итоге мне пришлось составить список пользовательских классов, соответствующих структуре таблицы.Похоже, что любой из способов привязки работает ниже.

Вот в случае, если это кому-то помогает:

protected void runReportForUser(Guid UserID)
    {
        pnCard.Visible = true;
        pnNoPoints.Visible = false;

        using (var db = new db())
        {
            // scorecard logic

            var u = userProfile.get(UserID);

            var t = db.Database.SqlQuery<EntityHistory>("exec dbo.ReturnEntities '" + u.userID.ToString() + "'");
            List<EntityHistory> EntityList = t.ToList<EntityHistory>();
            rptEvents.DataSource = EntityList;
            rptEvents.DataBind();

        }
    }

protected void rptEvents_ItemDataBound(object sender, RepeaterItemEventArgs e)
    {
        if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
        {
        EntityHistory EH = (EntityHistory)e.Item.DataItem;
            ((Label)e.Item.FindControl("lblDate")).Text = EH.dateCompleted;
            ((Label)e.Item.FindControl("lblCategory")).Text = DataBinder.Eval(e.Item.DataItem, "Category").ToString();
            ((Label)e.Item.FindControl("lblName")).Text = DataBinder.Eval(e.Item.DataItem, "Name").ToString();
            ((Label)e.Item.FindControl("lblPointsValue")).Text = DataBinder.Eval(e.Item.DataItem, "MaxPointsEach").ToString();
        }
    }

public class EntityHistory
{
    public Guid UserID { get; set; }
    public String dateCompleted {get;set;}
    public String Category { get; set; }
    public String Name { get; set; }
    public Int32 MaxPointsEach { get; set; }
}
...