Как лучше всего заполнить таблицу HTML в ASP.NET? - PullRequest
5 голосов
/ 04 сентября 2008

Это то, что у меня есть. Оно работает. Но есть ли более простой или лучший способ?

ASPX Page & hellip;

<asp:Repeater ID="RepeaterBooks" runat="server">
    <HeaderTemplate>
        <table class="report">
            <tr>
                <th>Published</th>
                <th>Title</th>
                <th>Author</th>
                <th>Price</th>
            </tr>
    </HeaderTemplate>
    <ItemTemplate>
            <tr>
                <td><asp:Literal ID="LiteralPublished" runat="server" /></td>
                <td><asp:Literal ID="LiteralTitle" runat="server" /></td>
                <td><asp:Literal ID="LiteralAuthor" runat="server" /></td>
                <td><asp:Literal ID="LiteralPrice" runat="server" /></td>
            </tr>
    </ItemTemplate>
    <FooterTemplate>
        </table>
    </FooterTemplate>
</asp:Repeater>

ASPX.VB Код позади & hellip;

Protected Sub Page_Load( ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
    Dim db As New BookstoreDataContext
    RepeaterBooks.DataSource = From b In db.Books _
                               Order By b.Published _
                               Select b
    RepeaterBooks.DataBind()
End Sub

Sub RepeaterBooks_ItemDataBound( ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles RepeaterBooks.ItemDataBound
    If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem Then
        Dim b As Book = DirectCast(e.Item.DataItem, Book)
        DirectCast(e.Item.FindControl("LiteralPublished"), Literal).Text = "<nobr>" + b.Published.ToShortDateString + "</nobr>"
        DirectCast(e.Item.FindControl("LiteralTitle"), Literal).Text = "<nobr>" + TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Title)) + "</nobr>"
        DirectCast(e.Item.FindControl("LiteralAuthor"), Literal).Text = "<nobr>" + TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Author)) + "</nobr>"
        DirectCast(e.Item.FindControl("LiteralPrice"), Literal).Text = "<nobr>" + Format(b.Price, "c") + "</nobr>"
    End If
End Sub

Function TryNbsp(ByVal s As String) As String
    If s = "" Then
        Return "&nbsp;"
    Else
        Return s
    End If
End Function

Ответы [ 8 ]

4 голосов
/ 04 сентября 2008

@ Джеф

Такого рода оператор Eval был фактически добавлен в 2.0, но если производительность важна, Eval следует избегать, поскольку он использует Reflection.

Повторитель - довольно хороший способ сделать это, хотя может быть быстрее сгенерировать таблицу в коде:

Страница ASPX:

<table class="report" id="bookTable" runat="server">
        <tr>
            <th>Published</th>
            <th>Title</th>
            <th>Author</th>
            <th>Price</th>
        </tr>
 </table>

Код сзади:

Protected Sub Page_Load( ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
    If Not Page.IsPostback Then
        BuildTable()
    End If
End Sub

Private Sub BuildTable()
    Dim db As New BookstoreDataContext
    Dim bookCollection = from b in db.Books _
                         Order By b.Published _
                         Select b
    Dim row As HtmlTableRow
    Dim cell As HtmlTableCell

    For Each book As Books In bookCollection
        row = New HtmlTableRow()
        cell = New HtmlTableCell With { .InnerText = b.Published.ToShortDateString }
        row.Controls.Add(cell)
        cell = New HtmlTableCell With { .InnerText = TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Title)) }
        row.Controls.Add(cell)
        cell = New HtmlTableCell With { .InnerText = TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Author))
        row.Controls.Add(cell)
        cell = New HtmlTableCell With { .InnerText = Format(b.Price, "c") }
        row.Controls.Add(cell)
        bookTable.Controls.Add(row)
    Next

Полагаю, это зависит от того, насколько важна для вас скорость. Ради простоты я думаю, что я бы пошел с повторителем.

3 голосов
/ 04 сентября 2008

Элемент управления ListView , представленный в framework 3.5, может быть немного лучшим решением. Ваша разметка будет выглядеть так:

<asp:ListView runat="server" ID="ListView1" 
    DataSourceID="SqlDataSource1">
  <LayoutTemplate>
    <table runat="server" id="table1" runat="server" >
      <tr runat="server" id="itemPlaceholder" ></tr>
    </table>
  </LayoutTemplate>
  <ItemTemplate>
    <tr runat="server>
      <td runat="server">
        <asp:Label ID="NameLabel" runat="server" 
          Text='<%#Eval("Name") %>' />
      </td>
    </tr>
  </ItemTemplate>
</asp:ListView>
2 голосов
/ 04 сентября 2008

В .Net 3.0+ вы можете заменить ItemDataBound на asp: Literal, выполнив что-то вроде этого:

<ItemTemplate>
            <tr>
                <td><%# Eval("published") %></td>
                ...

где "опубликовано" - это имя поля в данных, которые вы привязали к повторителю

Edit: @ Alassek : Я думаю, что производительность отражения часто переоценивается. Очевидно, вам нужно оценить производительность вашего приложения, но вероятность Eval, вероятно, измеряется в миллисекундах. Если ваше приложение не обслуживает много одновременных обращений, это, вероятно, не является проблемой, и простота кода, использующего Eval, наряду с хорошим разделением презентации делает его хорошим решением.

1 голос
/ 04 сентября 2008

Я бы использовал GridView (или DataGrid, если вы используете более старую версию ASP.NET).

<asp:GridView ID="gvBooks" runat="server" AutoGenerateColumns="False">
    <Columns>
        <asp:BoundField HeaderText="Published" DataField="Published" />
        <asp:BoundField HeaderText="Title" DataField="Title" />                     
        <asp:BoundField HeaderText="Author" DataField="Author" />
        <asp:BoundField HeaderText="Price" DataField="Price" />
    </Columns>
</asp:GridView>

С некоторым кодом:

Private Sub gvBooksRowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles gvBooks.RowDataBound
     Select Case e.Row.RowType
        Case DataControlRowType.DataRow

            ''' Your code here '''

     End Select
End Sub

Вы можете связать это аналогичным образом. Вам нужно событие RowDataBound.

1 голос
/ 04 сентября 2008

Для этого предназначен GridView.

<asp:GridView runat="server" DataSourceID="SqlDataSource1">
   <Columns>
      <asp:BoundField HeaderText="Published" DataField="Published" />
      <asp:BoundField HeaderText="Author" DataField="Author" />
   </Columns>
</asp:GridView>
1 голос
/ 04 сентября 2008

Я согласен с Джеффом, единственный раз, когда мы используем Literals, это если мы хотим сделать что-то другое с данными. Например, нам может потребоваться, чтобы в поле DueDate было указано «Сегодня» или «Вчера» вместо фактической даты.

0 голосов
/ 04 сентября 2008

Если вам не нужны возможности редактирования, обработанные ASP.NET, я бы держался в стороне от DataGrid и GridView ... они предоставляют ненужный набор .

0 голосов
/ 04 сентября 2008

ALassek писал (а):

& hellip; сгенерировать таблицу в коде & hellip;

Мне нравится, как это выглядит! Похоже, что НАМНОГО менее вероятно, чтобы вызвать исключение во время выполнения из-за опечатки или изменения имени поля.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...