ASP.NET - Έλεγχος DataList
- Προηγούμενη Σελίδα Repeater WebForms
- Επόμενη Σελίδα Σύνδεση βάσης δεδομένων WebForms
Ο έλεγχος DataList, παρόμοιος με τον έλεγχο Repeater, χρησιμοποιείται για την εμφάνιση επαναλαμβανόμενων λιστών αντικειμένων που περιορίζονται από τον έλεγχο. Ωστόσο, ο έλεγχος DataList προσθέτει αυτόματα πίνακα στους αντικειμένους δεδομένων.
Σύνδεση του DataSet με τον έλεγχο DataList
Ο έλεγχος DataList, παρόμοιος με τον έλεγχο Repeater, χρησιμοποιείται για την εμφάνιση επαναλαμβανόμενων λιστών αντικειμένων που περιορίζονται από τον έλεγχο. Ωστόσο, ο έλεγχος DataList προσθέτει αυτόματα πίνακα στους αντικειμένους δεδομένων. Ο έλεγχος DataList μπορεί να συνδεθεί με πίνακες βάσης δεδομένων, αρχεία XML ή άλλες λίστας αντικειμένων. Σε αυτό το παράδειγμα, θα δούμε πώς να συνδέσουμε ένα αρχείο XML σε έναν έλεγχο DataList.
Θα χρησιμοποιήσουμε τον παρακάτω αρχείο XML ("cdcatalog.xml") ως παράδειγμα:
<?xml version="1.0" encoding="ISO-8859-1"?> <κατάλογος> <cd> <title>Παραδοσιακός Αυτοκρατορικός</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>
Παρακαλώ ελέγξτε το αρχείο XML αυτό:cdcatalog.xml
Πρώτα, εισάγουμε το όνομα χώρο "System.Data" που χρειάζεται για να δουλέψουμε με τον αντικειμενοτύπο DataSet. Στο κεφάλι της σελίδας .aspx περιλαμβάνουμε την παρακάτω οδηγία:
<%@ Import Namespace="System.Data" %>
Τότε, δημιουργούμε έναν DataSet για αυτό το αρχείο XML και φορτώνουμε το αρχείο XML στον DataSet κατά την πρώτη φόρτωση της σελίδας:
<script runat="server"> sub Page_Load if Not Page.IsPostBack then dim mycdcatalog=New DataSet mycdcatalog.ReadXml(MapPath("cdcatalog.xml")) end if end sub
Στη συνέχεια, δημιουργούμε έναν έλεγχο DataList στη σελίδα .aspx. Το περιεχόμενο του στοιχείου <HeaderTemplate> εμφανίζεται μόνο μια φορά στην έξοδο, ενώ το περιεχόμενο του στοιχείου <ItemTemplate> αντιστοιχεί στο "record" του DataSet και επαναλαμβάνεται, τελικά, το περιεχόμενο του <FooterTemplate> εμφανίζεται μόνο μια φορά στην έξοδο:
<html> <body> <form runat="server"> <asp:DataList id="cdcatalog" runat="server"> <HeaderTemplate> ... </HeaderTemplate> <ItemTemplate> ... </ItemTemplate> <FooterTemplate> ... </FooterTemplate> </asp:DataList> </form> </body> </html>
Στη συνέχεια προσθέτουμε το σενάριο που δημιουργεί το DataSet και συνδέουμε το mycdcatalog DataSet στο DataList ελέγχου. Χρησιμοποιούμε επίσης αυτά τα στοιχεία για να συμπληρώσουμε τον ελέγχου DataList: το <HeaderTemplate> που περιέχει το κεφαλαίο, το <ItemTemplate> που περιέχει τα δεδομένα που θα εμφανιστούν, και το <FooterTemplate> που περιέχει κείμενο. Επίσης, η ιδιότητα gridlines του DataList είναι ρυθμισμένη σε "both", για να εμφανιστούν τα σύνορα της ταμπέλας:
<%@ 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:DataList id="cdcatalog" gridlines="both" runat="server"> <HeaderTemplate> My CD Catalog </HeaderTemplate> <ItemTemplate> "<%#Container.DataItem("title")%>" του <%#Container.DataItem("artist")%> - $<%#Container.DataItem("price")%> </ItemTemplate> <FooterTemplate> Copyright codew3c.com </FooterTemplate> </asp:DataList> </form> </body> </html>
Χρήση στυλ
Μπορείτε επίσης να προσθέσετε στυλ στο DataList ελέγχου, ώστε να γίνει πιο μοντέρνο:
<%@ 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:DataList id="cdcatalog" runat="server" cellpadding="2" cellspacing="2" borderstyle="inset" backcolor="#e8e8e8" width="100%" headerstyle-font-name="Verdana" headerstyle-font-size="12pt" headerstyle-horizontalalign="center" headerstyle-font-bold="true" itemstyle-backcolor="#778899" itemstyle-forecolor="#ffffff" footerstyle-font-size="9pt" footerstyle-font-italic="true" <HeaderTemplate> My CD Catalog </HeaderTemplate> <ItemTemplate> "<%#Container.DataItem("title")%>" του <%#Container.DataItem("artist")%> - $<%#Container.DataItem("price")%> </ItemTemplate> <FooterTemplate> Copyright codew3c.com </FooterTemplate> </asp:DataList> </form> </body> </html>
Χρήση του <AlternatingItemTemplate>
Μπορείτε να προσθέσετε το στοιχείο <AlternatingItemTemplate> μετά το <ItemTemplate>, ώστε να περιγράψετε την εμφάνιση των εναλλακτικών γραμμών. Μπορείτε να επεξεργαστείτε τη μορφοποίηση των δεδομένων στο τμήμα <AlternatingItemTemplate> του DataList ελέγχου:
<%@ 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:DataList id="cdcatalog" runat="server" cellpadding="2" cellspacing="2" borderstyle="inset" backcolor="#e8e8e8" width="100%" headerstyle-font-name="Verdana" headerstyle-font-size="12pt" headerstyle-horizontalalign="center" headerstyle-font-bold="True" itemstyle-backcolor="#778899" itemstyle-forecolor="#ffffff" alternatingitemstyle-backcolor="#e8e8e8" alternatingitemstyle-forecolor="#000000" footerstyle-font-size="9pt" footerstyle-font-italic="True"> <HeaderTemplate> My CD Catalog </HeaderTemplate> <ItemTemplate> "<%#Container.DataItem("title")%>" του <%#Container.DataItem("artist")%> - $<%#Container.DataItem("price")%> </ItemTemplate> <AlternatingItemTemplate> "<%#Container.DataItem("title")%>" του <%#Container.DataItem("artist")%> - $<%#Container.DataItem("price")%> </AlternatingItemTemplate> <FooterTemplate> © codew3c.com </FooterTemplate> </asp:DataList> </form> </body> </html>
- Προηγούμενη Σελίδα Repeater WebForms
- Επόμενη Σελίδα Σύνδεση βάσης δεδομένων WebForms