![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
|
Опции темы | Поиск в этой теме |
![]() |
#1 |
Пользователь
Регистрация: 12.09.2009
Сообщений: 33
|
![]()
Всем доброй ночи или вечера)
Мой вопрос заключается в том, что у меня имееться поле textbox, я должен ввести в него значения, чтобы бал произведен рассчет, как сделать так,что если поле пусто, то кнопка бы не работало или же писалось что необходимо заполнить строку (textbox) Например: Private Sub cmdRun_Click() Dim mmax as Integer mmax=txtM End Sub Получается на форме одно поле(textbox) и 1 кнопка Как реализовать описанное мною действие? |
![]() |
![]() |
![]() |
#2 |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]()
Самый простой вариант:
Код:
Вариант получше: Код:
В этом примере пользователь не сможет ввести в поле ничего, кроме цифр.
__Полезные надстройки для Excel. Парсинг сайтов и файлов.
![]() Последний раз редактировалось EducatedFool; 19.12.2009 в 18:33. |
![]() |
![]() |
![]() |
#3 |
Участник клуба
Регистрация: 10.08.2009
Сообщений: 1,796
|
![]()
Здравствуйте warshadow.
Предлагаю в код EducatedFool внести небольшую, непринципиальную корректировку: Код:
|
![]() |
![]() |
![]() |
#4 | |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]() Цитата:
1. Ваш код вылетит с ошибкой при вводе в текстбокс любого символа кириллицы 2. Я специально не стал добавлять в свой код возможность ввода запятой - поскольку ТС считывает значение в переменную типа Integer Код:
|
|
![]() |
![]() |
![]() |
#5 |
Участник клуба
Регистрация: 10.08.2009
Сообщений: 1,796
|
![]()
Здравствуйте EducatedFool.
Вы правы, конечно код должен быть изменен: Код:
ElseIf KeyAscii > 47 And KeyAscii < 58 Then Евгений. Последний раз редактировалось Teslenko_EA; 19.12.2009 в 20:53. |
![]() |
![]() |
![]() |
#6 |
Пользователь
Регистрация: 12.09.2009
Сообщений: 33
|
![]()
Спасибо вам за ответы))
Буду пробывать и выбирать тот вариант , который на мой взгляд кажется мне лучшим) |
![]() |
![]() |
![]() |
#7 |
Пользователь
Регистрация: 12.09.2009
Сообщений: 33
|
![]()
А еще такой вопрос есть как сделать так, чтобы если я ввожу целые числа выдывал что то в плане ошибки, а мог только вводить с запятой числа(и если ставлю "." - тоже писал ошибку) ?
и что обозначает ошибка "формула слишком сложна для присваивания объекту" --как можно исправить ее? Последний раз редактировалось warshadow; 20.12.2009 в 02:03. |
![]() |
![]() |
![]() |
#8 |
Пользователь
Регистрация: 12.09.2009
Сообщений: 33
|
![]()
Заранее спасибо
|
![]() |
![]() |
![]() |
#9 |
Участник клуба
Регистрация: 10.08.2009
Сообщений: 1,796
|
![]()
вводить только запятую разрешает строка ElseIf KeyAscii = 44 Then..., проверку ввода запятой можно выполнять следующим образом:
Код:
Код:
"Защитить" от проблемы сможет например: Dim mmax as Double Евгений. |
![]() |
![]() |
![]() |
#10 | |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]() Цитата:
![]() Вынужден констатировать, что Ваш код в некторых случаях будет работать неправильно. К примеру, после ввода в поле строки 4567,234 кнопка станет недоступной. Почему? Всё очень просто: выполнив команду debug.Print 8 and 5, в результате получим 0 Это достаточно распространённая, хотя и неочевидная ошибка. Правильно будет так: Код:
Код:
|
|
![]() |
![]() |
![]() |
|
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
textbox | NARTZISS | Общие вопросы .NET | 5 | 19.12.2009 14:21 |
TextBox(readonly) | Chartvit | Общие вопросы C/C++ | 1 | 21.11.2009 22:36 |
Проблема с TextBox | miatu | Microsoft Office Word | 3 | 10.09.2009 18:08 |
TextBox в С# | Natok | Помощь студентам | 2 | 18.05.2009 17:47 |
TextBox | Freeman | Общие вопросы C/C++ | 3 | 28.05.2008 00:56 |