Font-Italic="True" Font-Size="14"> Select an event to view details. </asp:Label>
<br>
<asp:Label Runat="server" ID="edDate" />
<br>
<asp:Label Runat="server" ID="edRoom" />
<br>
<asp:Label Runat="server" ID="edAttendees" />
</td>
</tr>
</table>
</td>
</tr>
</table>
Здесь
мы добавили новую строку таблицы, содержащую сведения с
DataList
в одном столбце и представленные данные в другом. Представление данных является просто четырьмя метками для свойств мероприятия, одна из которых содержит текст "Select an event to view details", когда не выбрано никакого мероприятия (ситуация при первой загрузке формы).
DataList
использует
<ItemTemplate>
и
<SelectedItemTemplate>
для вывода данных мероприятия. Чтобы облегчить выбор, мы инициируем команду
Select
внутри
<ItemTemplate>
, что автоматически изменяет выбор. Мы используем также для заполнения данными мероприятия событие
OnSelectedIndexChanged
, которое включается, когда команда
Select
изменяет выбор. Обработчик событий для этого показан ниже (Отметим, что нам нужно сначала выполнить метод
О шаблонах и элементах управления связыванием данных можно было бы написать целую книгу. Однако изложенного материала в данном разделе вполне достаточно для того, чтобы начать работать.
Конфигурация приложения
В этой главе без каких-либо подробностей упоминалось о существовании концептуального приложения, содержащего страницы и конфигурационные настройки. Это важная концепция для восприятия, особенно при конфигурировании web-сайтов множеством одновременных пользователей.
Сразу сделаем несколько замечаний о терминологии и времени жизни приложения.
Приложение определяется как все файлы проекта, оно сконфигурировано с помощью файлов
web.config
. Объект
Application
создается, когда приложение запускается в первый раз, что происходит, когда поступает первый запрос HTTP. В это время также срабатывает событие
Application_Start
, обработчик событий для которого детально описывается в
global.asax
(вместе со всеми другими событиями, обсуждаемыми здесь), и создается пул экземпляров
HttpApplication
. Каждый входящий запрос получает один из этих экземпляров, который выполняет обработку запроса (это означает, что объекты
HttpApplication
не нуждаются в копировании при одновременном доступе, в отличие от глобального объекта
Application
). Когда все экземпляры
HttpApplication
заканчивают свою работу срабатывает событие
Application_End
, и приложение прекращается, разрушая объект
Application
.
Когда отдельный пользователь использует приложение Web, запускается сеанс. Как и в случае приложения, это включает создание специфического для пользователя объекта
Session
вместе с включением события
Session_Start
. В течение сеанса в отдельные запросы могут входить события
Application_BeginRequest
и
Application_EndRequest
. Это повторяется несколько раз за сеанс, когда в приложении происходит доступ к различным ресурсам. Отдельные сеансы могут прекращаться вручную или будут прерываться, если не получают больше никаких запросов. Прекращение сеанса включает событие
Session_End
и разрушение объекта
Session
.
Как этот процесс может нам помочь? Существует несколько вещей, которые можно сделать, чтобы рационализировать приложение. Вернемся к приложению, которое разрабатывалось в этой главе. Каждый раз при доступе к странице .aspx множество записей заполняется содержимым
PCSWebApp3.mdb
. Это множество записей всегда используется только для считывания данных, так как для добавления мероприятий в базу данных используется другой метод. В таких случаях можно заполнить множество записей в обработчике событий
Application_Start
и сделать его доступным для всех пользователей. Единственный раз, когда понадобиться обновить множество записей, возникнет, если будет добавлено событие. Это существенно повышает производительность, так как в большинстве запросов не будет требоваться доступ к базе данных.