Используемая процедура | |
При нажатии любой клавиши | Процедура об работки события Key Press для элемента управления (для выяснения информации о нажатии отдельной клавиши) |
При любом изменении значения элемента управления | Процедура обработки события Change (для оценки значения) |
По окончании работы пользователя с элементом управления, непосредственно перед переходом к другому | Процедура обработки события Be Fore Update (позволяет отменить обновление данных и вернуть пользователя к текущему элементу управления) |
При закрытии формы пользователем | Процедура обработки события click для кнопок ОК или Закрыть в форме |
Вы сами должны выбрать подходящую для проверки процедуру, ответив на следующие вопросы.
* Насколько быстро должен выполняться программный код проверки?
* В какой момент нужно информировать об ошибке пользователя- в момент появления неправильного значения или уже после того, как пользователь закончит формирование вводимых данных?
* Основывается ли проверка на значениях, полученных от нескольких элементов управления?
Часть III Практикуемся в программировании на VBA
В этой части...
После того как вы познакомились с основами программирования на VBA и решили попробовать свои силы, вам пора изучить материал части III В главе 11 рассматриваются встроенные функции и операторы VBA; я не рекомендую вам создавать собственную процедуру, если встроенная функция сможет выполнить те же действия всего в одну строку. В главе 12 мы поговорим об использовании объектов. В главе 13 мы еще раз затронем тему управления данными, однако на этот раз речь будет идти о таких сложных вопросах, как использование массивов и коллекций.
Глава 11. Инструменты встроенного оркестра VBA.
В этой главе ...
~ Использование встроенных команд вместо нового изобретения программирования
~ Безопасное форматирование данных с помощью функции Format
~ Преобразование данных одних типов в другие
~ Работа с текстовыми строками
~ Забавы с датами и временем
~ Использование математических и финансовых функций
Прежде чем создавать свою собственную процедуру с чистого листа, убедитесь, что вы не изобретаете велосипед. Каждая версия VBA приходит с небольшим арсеналом встроенных команд, предназначенных для решения самых разнообразных часто возникающих задач. В этой главе предлагается обзор наиболее полезных из таких готовых к бою единиц вооружения. Кое-что в этот обзор не вошло и обсуждается среди прочего в других главах.
Знакомство со встроенными командами
Похоже, VBA немного не соответствует тому имиджу, который он себе создает. Ох, как отчаянно VBA хочет выглядеть истинным объектно-ориентированным языком программирования (об объектно- ориентированном программировании мы поговорим в главе 12). С другой стороны, следует признать, что есть кое-что, что вы хотели бы иметь в программе, но нельзя сказать, что это естественным образом умещается в матрицу объектно-ориентированного подхода.
В своем решении, достойном всех наших депутатов, VBA помещает в метод объекта как минимум одну команду, которую было бы естественнее оставить независимой, и в то же время оставляет независимыми другие действия, которые вполне подходят для связывания их с объектами.
В общем, учитывая, что некоторые действия могут оказаться в нелогичных для них категориях, вы получаете три типа встроенных VBA-команд, способных выполнять полезную работу.
* Операторы. Хотя термин оператор уже используется для обозначения целой программной директивы (см. главу 7), VBA называет операторами и отдельные ключевые слова, выполняющие специальные задачи. Некоторые из таких ключевых слов функционируют сами по себе как целые операторы. Например, оператор Веер заставляет динамик компьютера издавать звук. Другие же должны использоваться как составные части законченных операторов. Например, оператор ChDi r (перейти в каталог) бесполезен без аргумента, задающего каталог или папку, куда нужно перейти: