Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62

Пользовательская функция

02.07.2013, 08:29. Показов 2621. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, уважаемые форумчане.
Заранее извиняюсь за возможный повтор, но ничего подходящего не нашел.
Необходимо написать функцию грубо следующего вида:
Visual Basic
1
2
3
Public function myfunction ()
[Текущая форма].[текущий элемент].text = "123"
end function
Каким образом узнать текущий элемент,чтобы эту функцию вставлять в событие onkeypress элемента textbox например.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.07.2013, 08:29
Ответы с готовыми решениями:

Пользовательская функция
Дан радиус шара. Нужно рассчитать его площадь поверхности с помощью создания пользовательской функции (потом чтобы в библиотеке функции она...

Пользовательская функция
Здраствуйте! Помогите пожалуйста, Как создать пользовательскую функцию, которая по выбранному диапазону ячеек считала бы среднее значение...

Пользовательская функция
Помогите пожалуйста Физическое лицо имеет $x, €y, ₽z. Пересчитать общую сумму в рублях. Нужно написать пользовательскую функцию

9
200 / 98 / 2
Регистрация: 24.09.2011
Сообщений: 261
02.07.2013, 11:18
текущий элемент - это активный что-ли? На котором фокус? Тогда наверное
Visual Basic
1
me.ActiveContol.Caption = "123"
0
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62
03.07.2013, 09:26  [ТС]
Цитата Сообщение от sulfur Посмотреть сообщение
текущий элемент - это активный что-ли? На котором фокус? Тогда наверное
Visual Basic
1
me.ActiveContol.Caption = "123"
Текущий - тот который сгенерировал событие, в котором вызывается функция.

При попытке использовать предложенный вариант ошибка "invalid use of me keyword", к тому же он не подойдёт, если фокус находится на другом элементе.
0
10 / 5 / 0
Регистрация: 09.03.2013
Сообщений: 29
03.07.2013, 09:41
а передать имя элемента при вызове им функции этой не хотите?
0
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62
03.07.2013, 10:16  [ТС]
Вот, не знаю как в vba это делается...
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
05.07.2013, 15:58
Можно создать массив контролов, объявленный как класс. В классе - обработчик события.

Вот пример для кнопок:

Класс clsBtnArr
Visual Basic
1
2
3
4
5
6
Option Explicit
Public WithEvents BtnInArr As MSForms.CommandButton
 
Private Sub BtnInArr_Click()
    MsgBox BtnInArr.Name
End Sub
Модуль формы:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Option Explicit
Dim Btns() As New clsBtnArr
 
Private Sub UserForm_Initialize()
    Dim ctl As Control, i As Integer
    For Each ctl In Controls
        If TypeOf ctl Is msforms.CommandButton Then
            i = i + 1
            ReDim Preserve Btns(1 To i)
            Set Btns(i).BtnInArr = ctl
        End If
    Next ctl
End Sub
Вложения
Тип файла: xls Button array Events.xls (45.5 Кб, 17 просмотров)
2
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62
08.07.2013, 20:07  [ТС]
Dragokas, Спасибо!
0
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62
08.07.2013, 20:55  [ТС]
Dragokas, Я правильно понимаю, что если форма содержит, например, 10 textbox'ов (5 из которых обрабатываются одним способом, 5 другим), то нужно создавать два класса? пример прилагается.
Вложения
Тип файла: xls Книга1.xls (52.0 Кб, 10 просмотров)
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
08.07.2013, 21:16
Лучший ответ Сообщение было отмечено как решение

Решение

Anton Kadnikov, Вы можете поступить проще.
Не нужно создавать 2 класса и 2 группы объектов.
У каждого контролла есть свойство Tag.
Вы можете задать одно значение для Tag всех TextBox-ов 1-й группы, и другое значение для 2-й группы.

Из модуля класса проверять значение Tag и в зависимости от него выполнять то или иное действие:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Option Explicit
Public WithEvents BtnInArr As MSForms.CommandButton
 
Private Sub BtnInArr_Click()
    if BtnInArr.Tag = "1" then
       ' одно действие
    end if
    if BtnInArr.Tag = "2" then
       '  другое действие
    end if
End Sub
Миниатюры
Пользовательская функция  
1
4 / 4 / 1
Регистрация: 24.06.2013
Сообщений: 62
09.07.2013, 04:40  [ТС]
Dragokas, как вариант да, спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.07.2013, 04:40
Помогаю со студенческими работами здесь

Пользовательская функция
Доброго времени суток, столкнулся с трудностями при выполнении задания: Требуется разработать пользовательскую функцию для расчета...

Пользовательская функция с параметрами
Здравствуйте! Подскажите пожалуйста. Создаю функцию для скрытия или отображения рисунка с двумя параметрами. Первый параметр - это Ячейка,...

Пользовательская функция с циклом
Function G(b) As Double If b = 1 Then 'проверка на начальные условия G = 1 End If If b = 0.5 Then 'проверка на...

Пользовательская функция - оформление ?
Может кто знает, как сделать так чтобы когда вводишь на листе экселя свою функцию, там присутствовал некоторая подсказка, а не тупое...

Пользовательская функция в VBA
помогите создать пользовательскую функцию с параметром диапазон в VBA. нужно посчитать количество ячеек, текст в которых начинается и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru