Чтение онлайн

на главную - закладки

Жанры

C# для профессионалов. Том II

Ватсон Карли

Шрифт:

Код, который это делает,

getFreeDate
, показан ниже:

private System.DateTime getFreeDate(System.DateTime trialDate) {

 if (eventTable.Rows.Count > 0) {

System.DateTime=testDate;

bool trialDateOK = false;

while (!trialDateOK) {

trialDateOK = true;

foreach (System.Data.DataRow testRow in eventTable.Rows) {

testDate = (System.DateTime)TestRow["EventDate"];

if (testDate.Date == trialDate.Date) {

trialDateOK = false;

trialDate = trialDate.AddDays(1);

}

}

}

 }

 return trialDate;

}

Этот

простой код использует объект
eventTable
, который заполняется в
Page_Load
, для извлечения данных о мероприятии. Сначала мы проверяем тривиальный случай, где не заказано никаких мероприятий, в этом случае мы можем просто подтвердить пробную дату, возвращая ее. Затем мы просматриваем даты в таблице
Event
, сравнивая их с пробной датой. Если мы находим совпадение, то добавляем один день к пробной дате и снова выполняем поиск.

Извлечение даты из

DataTable
удивительно просто:

testDate = (System.DateTime)testRow["EventDate"];

Преобразование данных столбца в

System.DateTime
работает прекрасно.

Итак, прежде всего используем

getFreeDate
в
Page_Load
. Это просто означает внесение небольшого изменения в код, который задает свойство календаря
SelectedDate
:

if (!this.IsPostBack) {

 System.DateTime trialDate = System.DateTime.Now;

 calendar.SelectedDate = getFreeDate(trialDate);

 this.DataBind;

}

Затем нам нужно ответить на выбор даты в календаре. Чтобы сделать это, просто добавим обработчик событий для события календаря

SelectionChanged
и выполним сравнение даты с датами существующих мероприятий:

protected void calendar_SelectionChanged(object sender, System.EventArgs e) {

 System.DateTime trialDate = calendar.SelectedDate;

 calendar.SelectedDate = getFreeDate(trialDate);

}

Этот код идентичен коду в

Page_Load
.

Третий момент, когда необходимо выполнить эту проверку, возникает при нажатии кнопки заказа. Мы вернемся к этому немного позже, так как мы должны внести несколько изменений.

Затем мы хотим изменить цвет ячейки дня календаря, чтобы обозначить существующие мероприятия. Чтобы сделать это, необходимо добавить обработчик событий для события

DayRender
объекта календаря. Это событие происходит всякий раз при изображении отдельного дня и предоставляет нам доступ к объекту выводимой ячейки и дате этой ячейки с помощью свойств
Cell
и Date параметра
DayRenderEventArgs
функции обработчика. Нам нужно просто сравнить дату изображаемой
ячейки с датами в объекте
eventTable
и покрасить ячейку с помощью свойства
Cell.BackColor
, если существует совпадение:

protected void calendar_DayRender(object sender, System.Web.UI.WebControls.DayRenderEventArgs e) {

 if (eventTable.Rows.Count > 0) {

System.DateTime testDate;

fоreach (System.Data.DataRow testRow in eventTable.Rows) {

testDate = (System.DateTime)testRow["EventDate"];

if (testDate.Date == e.Day.Date) {

e.Cell.BackColor = Color.Red;

}

}

 }

}

В данном случае используется красный цвет, который дает нам следующее изображение:

Здесь 15, 27, 28, 29 и 30 марта содержат мероприятия, а пользователь выбирает 17 марта. Теперь, после добавления логики выбора даты, невозможно выбрать день, который показан красным цветом, и если делается такая попытка, то вместо этого будет выбрана следующая дата. Например, щелчок на 28 марта в показанном выше календаре приведет к выбору 31 марта.

Запись мероприятий в базу данных

Обработчик событий

submitButton_Click
в настоящее время собирает строку из характеристик мероприятия и выводит ее в элементе управления
resultLabel
. Чтобы добавить мероприятие в базу данных, нужно реформатировать созданную строку в запрос SQL
INSERT
и выполнить его.

Большая часть следующего кода выглядит знакомо:

protected void submitButton_Click(object sender, System.EventArgs e) {

 foreach (System.Web.UI.WebControls.WebControl validator in this.Validators) {

validator.Enabled = true;

 }

 this.Validate;

 if (this.IsValid) {

String attendees = "";

foreach (ListItem attendee in attendeeList.Items) {

if (attendee.Selected) {

attendees += attendee.Text + " (" + attendee.Value + "), ";

}

}

attendees += " and " + nameBox.Text;

String dateString =

calender.SelectedDate.Date.Date.ToShortDateString;

String oleDbCommand = "INSERT INTO Events (Name, Room, " +

"AttendeeList, EventDate) VALUES ('" + eventBox.Text + "', '" +

roomList.SelectedItem.Value + "', '" +

attendees + "', '" + dateString + "')";

После создания строки запроса SQL можно использовать ее для построения объекта

OleDb.OleDbCommand
:

Поделиться:
Популярные книги

Мастер 6

Чащин Валерий
6. Мастер
Фантастика:
боевая фантастика
попаданцы
аниме
5.00
рейтинг книги
Мастер 6

Инкарнатор

Прокофьев Роман Юрьевич
1. Стеллар
Фантастика:
боевая фантастика
рпг
7.30
рейтинг книги
Инкарнатор

Час Презрения

Сапковский Анджей
4. Ведьмак
Фантастика:
фэнтези
9.29
рейтинг книги
Час Презрения

Убивать чтобы жить 5

Бор Жорж
5. УЧЖ
Фантастика:
боевая фантастика
космическая фантастика
рпг
5.00
рейтинг книги
Убивать чтобы жить 5

Зауряд-врач

Дроздов Анатолий Федорович
1. Зауряд-врач
Фантастика:
альтернативная история
8.64
рейтинг книги
Зауряд-врач

Любимая учительница

Зайцева Мария
1. совершенная любовь
Любовные романы:
современные любовные романы
эро литература
8.73
рейтинг книги
Любимая учительница

Прометей: повелитель стали

Рави Ивар
3. Прометей
Фантастика:
фэнтези
7.05
рейтинг книги
Прометей: повелитель стали

Возвышение Меркурия. Книга 14

Кронос Александр
14. Меркурий
Фантастика:
попаданцы
аниме
5.00
рейтинг книги
Возвышение Меркурия. Книга 14

Тайны ордена

Каменистый Артем
6. Девятый
Фантастика:
боевая фантастика
попаданцы
7.48
рейтинг книги
Тайны ордена

Камень. Книга вторая

Минин Станислав
2. Камень
Фантастика:
фэнтези
8.52
рейтинг книги
Камень. Книга вторая

Флеш Рояль

Тоцка Тала
Детективы:
триллеры
7.11
рейтинг книги
Флеш Рояль

Шесть принцев для мисс Недотроги

Суббота Светлана
3. Мисс Недотрога
Фантастика:
фэнтези
7.92
рейтинг книги
Шесть принцев для мисс Недотроги

Звездная Кровь. Изгой

Елисеев Алексей Станиславович
1. Звездная Кровь. Изгой
Фантастика:
боевая фантастика
попаданцы
рпг
5.00
рейтинг книги
Звездная Кровь. Изгой

Последняя Арена 6

Греков Сергей
6. Последняя Арена
Фантастика:
рпг
постапокалипсис
5.00
рейтинг книги
Последняя Арена 6