Los últimos tutoriales de desarrollo web
 

ASP.NET Web Forms - El control DataList


El control DataList es, al igual que el control Repeater, que se utiliza para mostrar una lista de elementos repetidos que están vinculados con el control. Sin embargo, el control DataList añade una mesa alrededor de los elementos de datos por defecto.


Enlazar un conjunto de datos a un control DataList

El control DataList es, al igual que el control Repeater, que se utiliza para mostrar una lista de elementos repetidos que están vinculados con el control. Sin embargo, el control DataList añade una mesa alrededor de los elementos de datos por defecto. El control DataList puede estar unido a una tabla de base de datos, un archivo XML, u otra lista de elementos. Aquí vamos a mostrar cómo enlazar un archivo XML para un control DataList.

Vamos a utilizar el siguiente archivo XML en nuestros ejemplos ("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>

Echar un vistazo al archivo XML: cdcatalog.xml

En primer lugar, importe el "System.Data" espacio de nombres. Necesitamos este espacio de nombres para trabajar con objetos DataSet. Incluir la siguiente directiva en la parte superior de una página .aspx:

<%@ Import Namespace="System.Data" %>

A continuación, cree un conjunto de datos para el archivo XML y cargar el archivo XML en el conjunto de datos cuando se carga por primera vez la página:

<script runat="server">
sub Page_Load
if Not Page.IsPostBack then
  dim mycdcatalog=New DataSet
  mycdcatalog.ReadXml(MapPath("cdcatalog.xml"))
end if
end sub

Entonces se crea una DataList en una página .aspx. El contenido de la <HeaderTemplate> elemento se procesan primero y sólo una vez en la salida, entonces el contenido de la <ItemTemplate> elemento se repiten para cada "record" en el conjunto de datos, y por último, el contenido de la <FooterTemplate> elemento son rindió una vez dentro de la salida:

<html>
<body>

<form runat="server">
<asp:DataList id="cdcatalog" runat="server">

<HeaderTemplate>
...
</HeaderTemplate>

<ItemTemplate>
...
</ItemTemplate>

<FooterTemplate>
...
</FooterTemplate>

</asp:DataList>
</form>

</body>
</html>

A continuación, añadimos la secuencia de comandos que crea el conjunto de datos y se une al conjunto de datos mycdcatalog al control DataList. También llenamos el control DataList con un <HeaderTemplate> que contiene la cabecera de la mesa, un <ItemTemplate> que contiene los elementos de datos para mostrar, y una <FooterTemplate> que contiene un texto. Tenga en cuenta que la gridlines atributo del DataList está ajustado a "both" para mostrar los bordes de tabla:

Ejemplo

<%@ 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")%>" of
<%#Container.DataItem("artist")%> -
$<%#Container.DataItem("price")%>
</ItemTemplate>

<FooterTemplate>
Copyright Hege Refsnes
</FooterTemplate>

</asp:DataList>
</form>

</body>
</html>
Ver ejemplo »

Uso de estilos

También puede agregar estilos con el control DataList para que la salida más elegante:

Ejemplo

<%@ 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")%>" of
<%#Container.DataItem("artist")%> -
$<%#Container.DataItem("price")%>
</ItemTemplate>

<FooterTemplate>
Copyright Hege Refsnes
</FooterTemplate>

</asp:DataList>
</form>

</body>
</html>
Ver ejemplo »

Utilizando el <AlternatingItemTemplate>

Se puede añadir un <AlternatingItemTemplate> elemento después del <ItemTemplate> elemento para describir la apariencia de filas de salida alterna. Es posible que el estilo de los datos en el <AlternatingItemTemplate> sección dentro del control DataList:

Ejemplo

<%@ 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")%>" of
<%#Container.DataItem("artist")%> -
$<%#Container.DataItem("price")%>
</ItemTemplate>

<AlternatingItemTemplate>
"<%#Container.DataItem("title")%>" of
<%#Container.DataItem("artist")%> -
$<%#Container.DataItem("price")%>
</AlternatingItemTemplate>

<FooterTemplate>
&copy; Hege Refsnes
</FooterTemplate>

</asp:DataList>
</form>

</body>
</html>
Ver ejemplo »