ASP.NET - Repeater-knop
- Vorige pagina WebForms XML File
- Volgende pagina WebForms DataList
De Repeater-knop wordt gebruikt om herhaalde itemlijsten weer te geven, die beperkt zijn tot de knop.
Voorbeeld
DataSet koppelen aan de Repeater-knop
De Repeater-knop wordt gebruikt om herhaalde itemlijsten weer te geven, die beperkt zijn tot de knop. De Repeater-knop kan worden gekoppeld aan een database tabel, een XML-bestand of andere itemlijsten. Hier tonen we hoe je een XML-bestand kunt koppelen aan een Repeater-knop.
We zullen in dit voorbeeld het volgende XML-bestand gebruiken ("cdcatalog.xml"):
<?xml version="1.0" encoding="ISO-8859-1"?> <catalog> <cd> <title>Empire Burlesque</title> <artist>Bob Dylan</artist> <country>USA</country> <company>Columbia</company> <price>10.90</price> <year>1985</year> </cd> <cd> <title>Hide your heart</title> <artist>Bonnie Tyler</artist> <country>UK</country> <company>CBS Records</company> <price>9.90</price> <year>1988</year> </cd> <cd> <title>Greatest Hits</title> <artist>Dolly Parton</artist> <country>USA</country> <company>RCA</company> <price>9.90</price> <year>1982</year> </cd> <cd> <title>Still got the blues</title> <artist>Gary Moore</artist> <country>UK</country> <company>Virgin records</company> <price>10.20</price> <year>1990</year> </cd> <cd> <title>Eros</title> <artist>Eros Ramazzotti</artist> <country>EU</country> <company>BMG</company> <price>9.90</price> <year>1997</year> </cd> </catalog>
Bekijk het volgende XML-bestand:cdcatalog.xml
Eerst, importeer de "System.Data" naamruimte. We hebben deze naamruimte nodig om samen te werken met de DataSet-objecten. Op de top van de .aspx-pagina bevat de volgende instructie:
<%@ Import Namespace="System.Data" %>
Vervolgens maken we een Repeater-kontrol aan in de .aspx-pagina. De inhoud van het <HeaderTemplate>-element verschijnt slechts een keer in de uitvoer, de inhoud van het <ItemTemplate>-element verschijnt in overeenstemming met de "record" in de DataSet, en tenslotte verschijnt de inhoud van het <FooterTemplate>-element slechts een keer in de uitvoer:
<script runat="server"> sub Page_Load if Not Page.IsPostBack then dim mycdcatalog=New DataSet mycdcatalog.ReadXml(MapPath("cdcatalog.xml")) end if end sub
Vervolgens maken we een DataSet voor deze XML-bestand en laden we dit XML-bestand in de DataSet bij het eerste laden van de pagina:
<html> <body> <form runat="server"> <asp:Repeater id="cdcatalog" runat="server"> <HeaderTemplate> ... </HeaderTemplate> <ItemTemplate> ... </ItemTemplate> <FooterTemplate> ... </FooterTemplate> </asp:Repeater> </form> </body> </html>
Vervolgens voegen we een script toe om een DataSet te kunnen maken en binden we deze mycdcatalog DataSet aan de Repeater-kontrol. We vullen deze Repeater-kontrol ook met HTML tags en koppelen de data items aan de cellen in het <ItemTemplate>-gedeelte met behulp van de methode <%#Container.DataItem("fieldname")%>:
<%@ Import Namespace="System.Data" %> <script runat="server"> sub Page_Load if Not Page.IsPostBack then dim mycdcatalog=New DataSet mycdcatalog.ReadXml(MapPath("cdcatalog.xml")) cdcatalog.DataSource=mycdcatalog cdcatalog.DataBind() end if end sub </script> <html> <body> <form runat="server"> <asp:Repeater id="cdcatalog" runat="server"> <HeaderTemplate> <table border="1" width="100%"> <tr> <th>Titel</th> <th>Artiest</th> <th>Land</th> <th>Bedrijf</th> <th>Prijs</th> <th>Jaar</th> </tr> </HeaderTemplate> <ItemTemplate> <tr> <td><%#Container.DataItem("title")%></td> <td><%#Container.DataItem("artist")%></td> <td><%#Container.DataItem("country")%></td> <td><%#Container.DataItem("company")%></td> <td><%#Container.DataItem("price")%></td> <td><%#Container.DataItem("year")%></td> </tr> </ItemTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> </form> </body> </html>
Gebruik <AlternatingItemTemplate>
U kunt een <AlternatingItemTemplate>-element toevoegen na het <ItemTemplate>-element om het uiterlijk van afwisselende rijen te beschrijven. In het volgende voorbeeld wordt elke andere rij van de tabel weergegeven met een lichte grijze achtergrond:
<%@ Import Namespace="System.Data" %> <script runat="server"> sub Page_Load if Not Page.IsPostBack then dim mycdcatalog=New DataSet mycdcatalog.ReadXml(MapPath("cdcatalog.xml")) cdcatalog.DataSource=mycdcatalog cdcatalog.DataBind() end if end sub </script> <html> <body> <form runat="server"> <asp:Repeater id="cdcatalog" runat="server"> <HeaderTemplate> <table border="1" width="100%"> <tr> <th>Titel</th> <th>Artiest</th> <th>Land</th> <th>Bedrijf</th> <th>Prijs</th> <th>Jaar</th> </tr> </HeaderTemplate> <ItemTemplate> <tr> <td><%#Container.DataItem("title")%></td> <td><%#Container.DataItem("artist")%></td> <td><%#Container.DataItem("country")%></td> <td><%#Container.DataItem("company")%></td> <td><%#Container.DataItem("price")%></td> <td><%#Container.DataItem("year")%></td> </tr> </ItemTemplate> <AlternatingItemTemplate> <tr bgcolor="#e8e8e8"> <td><%#Container.DataItem("title")%></td> <td><%#Container.DataItem("artist")%></td> <td><%#Container.DataItem("country")%></td> <td><%#Container.DataItem("company")%></td> <td><%#Container.DataItem("price")%></td> <td><%#Container.DataItem("year")%></td> </tr> </AlternatingItemTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> </form> </body> </html>
Gebruik <SeparatorTemplate>
Het <SeparatorTemplate>-element kan worden gebruikt om de separator tussen elke record te beschrijven. In het volgende voorbeeld wordt een horizontale lijn ingevoegd tussen elke rij van de tabel:
<%@ Import Namespace="System.Data" %> <script runat="server"> sub Page_Load if Not Page.IsPostBack then dim mycdcatalog=New DataSet mycdcatalog.ReadXml(MapPath("cdcatalog.xml")) cdcatalog.DataSource=mycdcatalog cdcatalog.DataBind() end if end sub </script> <html> <body> <form runat="server"> <asp:Repeater id="cdcatalog" runat="server"> <HeaderTemplate> <table border="0" width="100%"> <tr> <th>Titel</th> <th>Artiest</th> <th>Land</th> <th>Bedrijf</th> <th>Prijs</th> <th>Jaar</th> </tr> </HeaderTemplate> <ItemTemplate> <tr> <td><%#Container.DataItem("title")%></td> <td><%#Container.DataItem("artist")%></td> <td><%#Container.DataItem("country")%></td> <td><%#Container.DataItem("company")%></td> <td><%#Container.DataItem("price")%></td> <td><%#Container.DataItem("year")%></td> </tr> </ItemTemplate> <SeparatorTemplate> <tr> <td colspan="6"><hr /></td> </tr> </SeparatorTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> </form> </body> </html>
- Vorige pagina WebForms XML File
- Volgende pagina WebForms DataList