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"?> <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>
Пожалуйста, посмотрите на этот XML-файл:cdcatalog.xml
Сначала импортируйте пространство имен "System.Data" . Нам нужно это пространство имен для работы с объектом DataSet. Вверху страницы .aspx включите следующее directive:
<%@ Import Namespace="System.Data" %>
Далее создайте DataSet для этого 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> повторяется в соответствии с DataSet, содержащим "record", и, наконец, содержимое <FooterTemplate> отображается только один раз в выводе:
<html> <body> <form runat="server"> <asp:DataList id="cdcatalog" runat="server"> <HeaderTemplate> ... </HeaderTemplate> <ItemTemplate> ... </ItemTemplate> <FooterTemplate> ... </FooterTemplate> </asp:DataList> </form> </body> </html>
Затем мы добавляем скрипт, который создает DataSet, и绑定 этот DataSet mycdcatalog к контролу 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> Мой каталог CD </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> Мой каталог CD </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> Мой каталог CD </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