2009-06-04 5 views
1

Lorsque j'ai une table dans la base de données avec beaucoup de lignes et je veux les afficher par ligne normale (pas avec Gridview). Comme:afficher plusieurs lignes de DB par ligne normale?

Vous enseignez ces classes: classe 1/1, classe 2/1, classe 3/1

nous prenons (1/1 et 3/1) et 2/1 de base de données.

comment puis-je le faire?

note: j'utilise LINQ pour gérer la base de données.

Répondre

1

L'utilisation d'un répéteur semble être le moyen le plus facile pour moi. Cela ressemblerait à quelque chose comme ça.

<div> 
    You teach these classes: 
    <asp:Repeater 
     ID="rptListOfClasses" 
     runat="server" 
     DataSourceID="linqDataSource" > 
     <ItemTemplate> 
      <span> class <%# Eval("ClassDate") %>, </span> 
     </ItemTemplate> 
    </asp:Repeater> 
</div> 
0
<asp:ListView ID="lvClass" runat="server" DataSourceID="LinqDataSource1" OnItemDataBound ="lvResult_ItemDataBound" > 
    <LayoutTemplate> 
     You teach these classes:&nbsp; 
     <asp:PlaceHolder runat="server" ID="itemPlaceHolder" ></asp:PlaceHolder> 
    </LayoutTemplate> 
    <ItemTemplate> 
      <asp:Label ID="lblClass" runat="server" Text='<%# DataBinder.Eval(Container.DataItem, "Class") + ", " %>' ></asp:Label>           
    </ItemTemplate> 

</asp:ListView> 


<asp:LinqDataSource ID="LinqDataSource1" runat="server" 
    ContextTypeName="MyDataContext" TableName="ClassList" 
    onselected="LinqDataSource1_Selected"> 
</asp:LinqDataSource> 

code Derrière: // supprimer la virgule (,)

public class Test : System.Web.UI.Page 
    { 
     int iCount = 0; 
protected void lvResult_ItemDataBound(object sender, ListViewItemEventArgs e) 
     { 
      if (e.Item.ItemType == ListViewItemType.DataItem) 
      { 

       Label lblClass = e.Item.FindControl("lblClass") as Label; 
       ListViewDataItem lvItem = e.Item as ListViewDataItem ; 
       if (lblClass != null) 
        if (lvItem.DataItemIndex == (iCount - 1)) 
         lblClass.Text = lblClass.Text.Substring(0, lblClass.Text.ToString().Length - 2); 



      } 
     } 

     protected void LinqDataSource1_Selected(object sender, LinqDataSourceStatusEventArgs e) 
     { 
      iCount = e.TotalRowCount; 
     } 

} 
Questions connexes