, чтобы гарантировать, что эти данные обновляются, когда добавляются новые записи:
if (queryResult == 1) {
resultLabel.Text = "Event Added.";
daEvents =
new System.Data.OleDb.OleDbDataAdapter("SELECT * FROM Events", oleDbConnection1);
ds.Clear;
daEvents.Fill(ds, "Events");
eventTable = ds.Tables["Events"];
calendar.SelectedDate =
getFreeDate(calendar.SelectedDate.AddDaysd));
eventDetails1.DataBind;
}
Отметим,
что мы вызываем
DataBind
на
DataGrid
, а не на
this
. Это препятствует обновлению любых данных элементов управления соединения, что было бы не нужно. Все элементы управления соединением данных поддерживают этот метод, который обычно вызывается формой, если вызывается метод верхнего уровня
(this)dataBind
.
Элемент управления
DataGrid
содержит немало свойств, которые можно использовать для форматирования выводимых данных в более удобном для пользователя виде, но это оставляется читателю для самостоятельного рассмотрения.
Вывод данных с помощью шаблонов
Два других элемента управления выводом данных —
Repeater
и
DataList
, требуют использования шаблонов для форматирования данных для вывода. Шаблонами в смысле ASP.NET являются параметризованные разделы кода HTML, которые используются как элементы вывода в некоторых элементах управления. Они позволяют точно определить, как данные выводятся в браузере, и могут создать без существенных усилий профессионально сделанное представление.
Существует несколько шаблонов для настройки различных аспектов поведения списка, но шаблоном, который является важным для
Repeater
и
DataList
, является шаблон
<ItemTemplate>
, используемый при выводе каждого элемента данных. Мы объявляем этот шаблон (и все остальные) внутри объявления элемента управления, например:
<asp:DataList Runat="server" ... >
<ItemTemplate>
...
</ItemTemplate>
</asp:DataList>
Внутри объявлений шаблонов нам нужно будет выводить разделы HTML, включая параметры с данными, связанными с элементом управления. Существует специальный синтаксис, который можно использовать для вывода таких параметров:
<%# expression %>
expression
может быть просто выражением, связывающим параметр со свойством страницы или элемента управления, но, скорее, состоит из выражения
DataBinder.Eval
. Эта полезная функция может использоваться для вывода данных из таблицы, связанной с элементом управления, определяя столбец с помощью следующего синтаксиса:
Существует также необязательный третий параметр, позволяющий сформатировать возвращаемые данные, который имеет синтаксис, идентичный выражениям форматирования строк, используемым в других местах.
Полное описание доступных шаблонов дано в следующей таблице:
Шаблон
Описание
<ItemTemplate>
Шаблон
используется для элементов списка.
<HeaderTemplate>
Шаблон используется для вывода перед списком.
<FooterTemplate>
Шаблон используется для вывода после списка.
<SeparatorTemplate>
Шаблон используется между элементами списка.
<AlternatingItemTemplate>
Шаблон для альтернативных элементов, способствует проявлению видимости.
<SelectedItemTemplate>
(Только
DataList
) Шаблон используется для выбранных элементов в списке.
<EditItemTemplate>
(Только
DataList
) Шаблон используется для элементов в списке, которые редактируются.
Рассмотрим это на примере. Используем для него запрос существующих данных в
PCSWebApp3
.
Пример
Расширим таблицу вверху страницы, чтобы она содержала
DataList
, выводящий каждое из мероприятий, хранящихся в базе данных. Мы сделаем эти мероприятия выбираемыми, чтобы данные любого мероприятия можно было вывести, щелкая на его имени. Изменения в коде в
PCSWebApp3
показаны ниже:
<tr>
<td align=middle colSpan=3>
<asp:validationsummary id=validationSummary Runat="server" headertext="Before submitting your request:" />