Как вы уже, наверное, поняли, почти все в Access является объектом. Одной из особенностей объектов является их способность распознавать события, представляющие собой некие действия, и реагировать на них. Практически все объекты распознают щелчки, двойные щелчки и перемещение мыши. Помимо этого, большинство объектов распознают и другие события. Так, например, элемент управления поле распознает 17 событий, а форма - более 50.
При работе с формой объекты практически постоянно сигнализируют события. Часть событий Access обрабатывает, но большинство игнорирует. Для событий, которые Access распознает, но не обрабатывает, можно указать действие, которое следует выполнить после наступления данного события (например, запустить макрос, решающий определенную задачу).
Все это звучит довольно сложно. К тому же события не относятся к числу понятий, о которых задумывается обычный пользователь. Тем не менее стоит уделить им внимание, если вас интересует, что происходит при вводе данных и как добиться большей эффективности объектов формы.
В базе данных GardenCo код клиента состоит из трех первых букв фамилии и двух первых букв имени, причем все буквы заглавные. Подобная методика позволяет создать уникальный код клиента. При попытке ввести код, который уже используется, Access заблокирует поле, и вам придется изменить код (например, добавить цифру), чтобы обеспечить его уникальность. Компьютер легко справляется с такими задачами, как объединение частей двух слов и преобразование букв в прописные. Поэтому, вместо того чтобы вводить код клиента вручную для каждой новой записи, предоставьте эту функцию VBA-программе.
В этом упражнении вы напишете небольшую VBA-программу и свяжете ее с событием После обновления (After Update) в поле Фамилия формы Клиенты. Если изменить содержимое поля и попытаться перейти к другому элементу формы, генерируется событие Перед обновлением (Before Update). Access реагирует на это событие, обновляя запись в исходной таблице, после чего генерируется событие После обновления (After Update), обработкой которого вы и займетесь. Это упражнение не является глубоким погружением в Visual Basic, но дает представление о его возможностях. В качестве рабочей папки будет использоваться Office XP SBS\Access\Chap11\Events. Выполните следующие шаги.
В окне программы отображается процедура Private Sub Фамилия_AfterUpdate, которая будет использоваться для обработки события После обновления (After Update) в поле Фамилия. На данном этапе она состоит только из двух утверждений, определяющих ее начало (Sub) и конец (End Sub).
'Создайте переменные для Имени, Фамилии 'и Кода клиента Dim fName As String Dim lName As String Dim cID As String 'Присвойте значения переменной lName из текстового 'поля Фамилия. lName = Forms!клиенты!Фамилия.Text 'Вы должны активизировать текстовое поле прежде, 'чем прочитать его содержание. Forms!клиенты!Имя.SetFocus fName = Forms!клиенты!Имя.Text 'Объедините части Фамилии и Имени 'для создания Кода клиента. cID = UCase(Left(lName, 3) & Left(fName, 2)) 'Не храните Код, если только это не 5 знаков. '(Это означает, что оба имени заполнены.) If Len(cID) = 5 Then Forms!клиенты!КодКлиента.SetFocus 'Не изменяйте Код, если он уже был введен. 'Возможно, это было сделано вручную. If Forms!клиенты!КодКлиента.Text = "" Then Forms!клиенты!КодКлиента = cID End If End If 'Активизировать поле ввода Адреса. Forms!клиенты!Адрес.SetFocus