События
Здравствуйте, уважаемые читатели.
Поговорим в этом выпуске об очень интересной штуке – события. Я очень мало где видел их использование в MS Access. Но они очень сильно облегчают жизнь при работе, особенно с формами. У событий есть маленькое ограничение. Их могут использовать только объекты. Это означает, что их можно объявлять и получать только в модулях пользовательских классов, формах и отчетах.
Чтобы объявить событие необходимо в начале модуля класса (формы, отчета или пользовательского) написать:
Event ИмяСобытия( СписокАргументов )
Для использовании события необходимо объявить в начале модуля ссылку на объект и в списке (левый список, который расположен в редакторе кода) выбрать обявленный атрибут, в правом списке можно выбрать событие, если их несколько. В результате получим следующее:
Dim WithEvents Имя As Тип
Вызвать событие можно так:
RaiseEvent ИмяСобытия( Параметры )
Где это можно применить? Рассмотрим пример из жизни. На форме заказа есть поле клиента. В этом поле отображается, допустим, УНН и название клиента. Рядом с полем кнопка. По нажатию на кнопке отображается еще одна форма – список клиентов. Задача – выбрать клиента.
Одним из решений будет открыть модальное окно и тут возникает куча разных вариантов: записать напрямую с формы списка клиентов в поле формы заказов (очень плохая идея!!!), скрыть форму при нажатии пользователем кнопки “Ок” (Выбрать) и т.д.
При помощи событий получается простое и элегантное решение. Всего-то объявить на форме списка клиентов событие:
Event OnClientSelect(ByVal lId As Long)
На форме заказа это событие обработать:
Dim WithEvents m_frmKlientSepis As Form_frmKlientSpis
'--
Private Sub Kn_KlientSelect_Click()
'-- выбор клиента
'-- можно и так
'-- DoCmd.OpenForm "frmKlientSpis"
'-- Set m_frmKlientSepis = Forms("frmKlientSpis")
'-- но мне нравится этот вариант
Set m_frmKlientSepis = New Form_frmKlientSpis
m_frmKlientSepis.Visible = True
End Sub
Private Sub m_frmKlientSepis_OnClientSelect(ByVal lK_KLIENT As Long)
'-- клиент выбран пользователем
Me.K_KLIENT = lK_KLIENT
Set m_frmKlientSepis = Nothing '-- уничтожаем форму
End Sub
Подробности можете увидеть в примере. Чуть позже я расмотрю еще один пример – связные списки.
До скорых встреч!
(с) Скоков Сергей
А тут автор на комметы вообще не отвечает что ли?
Сеня
9 Окт 08 at 06:16