powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Как закрыть все открытые юзером формы через For Each ?
25 сообщений из 36, страница 1 из 2
Как закрыть все открытые юзером формы через For Each ?
    #32419153
Фотография # Darth Vader #
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Надо с помощью Public Sub позакрывать все формы открытые юзером.
Сначала определить загружена ли форма и если она открыта закрыть ее.
Но вот как?
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32419155
Фотография АлексейК
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
свойство isloaded у объектов семейcтва allforms
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32419232
Фотография # Darth Vader #
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
этого свойства что то не нашел.

Public Sub CloseAllForms()

Dim allfrm As AllForms


?????

End Sub
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32419246
Фотография Alviga
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
For each xForm in Forms
Unload xForm
next
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32419327
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Sub CloseAllForms()
Do Until Forms.Count = 0
DoCmd.Close acForm, Forms(0).Name
Loop
End Sub
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32419391
Фотография # Darth Vader #
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Спасибо всем. Действует.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420012
Фотография Geo
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сергей ГавриловDo Until Forms.Count = 0
DoCmd.Close acForm, Forms(0).Name
Loop
Только это не будет работать с несколькими экземплярами формы.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420386
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
GeoТолько это не будет работать с несколькими экземплярами формы.
У меня работает. Что я неправильно делаю? :-)
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420445
Фотография # Darth Vader #
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
У меня тоже работает.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420455
Фотография Лох Позорный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
А вы точно несколько экземпляров одной формы открываете?
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420483
проверили. Работает.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420529
Фотография Лифчик
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
А если в коллекции нет ни одной формы хотя бы в одном экземпляре, то значит нет и в нескольких экземплярах? :-)
утверждение
А бывают формы, которые открыты, но в коллекции не значатся (типа приехали в москву и живут без регистрации :-)
шутка
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32420901
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторА если в коллекции нет ни одной формы хотя бы в одном экземпляре, то значит нет и в нескольких экземплярах? :-)
Осторожнее надо, чуть голову не сломал, читая это :-)
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421533
Фотография Geo
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
Public Function aaa()
  Dim f1 As Form
  Dim f2 As Form
  Set f1 = New Form_Форма1
  Set f2 = New Form_Форма1
  f1.Visible = True
  f2.Visible = True
'***************
  MsgBox Forms( 0 ).Name
  Do Until Forms.Count =  0 
    DoCmd.Close acForm, Forms( 0 ).Name
  Loop
End Function


Странно. На работе (а97 sr1) не работает. Дома (a97 sr2, aXP sp 2) работает.
Вывод - ставьте сервис-паки.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421557
Фотография Владимир Саныч
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Модератор форума
GeoDoCmd.Close acForm, Forms(0).Name
Если открыто 10 форм под названием MyForm и я делаю
DoCmd.Close acForm, "MyForm"
то закрывается произвольная из 10? Разве это может кого-то устраивать?
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421574
Фотография Geo
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2ВС
Когда надо закрыть все формы, то может.
А если при этом выскакивает ошибка, то не может :)
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421599
Фотография Владимир Саныч
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Модератор форума
Секундочку. У меня принципиальный вопрос. Прошу прощения, что задаю его тут, а не в специальном топике про экземпляры форм.

DoCmd.Close acForm, имя - это единственный способ закрыть форму??? Только по имени??? И в кнопке "Выход" тоже???

Если открыто 10 форм под названием MyForm и у каждой в кнопке "Выход" написано
DoCmd.Close acForm, Me.Name
то кнопка "Выход" закрывает произвольную форму из 10???
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421697
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторDoCmd.Close acForm, имя - это единственный способ закрыть форму??? Только по имени??
Ну почему, есть и кнопка X :)
Если форма открыта через объектную переменную, то тоже понятно как ее можно закрыть.
авторЕсли открыто 10 форм под названием MyForm и у каждой в кнопке "Выход" написано
DoCmd.Close acForm, Me.Name
то кнопка "Выход" закрывает произвольную форму из 10???
Да, действительно, кнопка закрывает первую из форм. Т.е. нажимаем кнопку выход (в которой DoCmd.Close acForm, Me.Name) на одной форме, а может закрытся другая (проверено).
Правда, можно закрывать форму командой DoCmd.Close. Тогда закрывается активная форма. Но мне кажется, что иногда бываю глюки, может просто кажется...
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421701
Фотография Владимир Саныч
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Модератор форума
Глюки действительно бывают. Поэтому я приучился писать DoCmd.Close acForm, Me.Name, а не просто DoCmd.Close.

И выходит, что на форме, открываемой в нескольких экземплярах, невозможно сделать кнопку "Выход"???
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421703
Фотография Темный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Меняй ей Caption при открытии, а потом проверяй его на соответствие в For Each
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421706
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторИ выходит, что на форме, открываемой в нескольких экземплярах, невозможно сделать кнопку "Выход"???
Ну почему? Кнопку-то можно, только код делать другой, например, вызывающий действие по сбросу объектной переменной.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421707
Фотография Владимир Саныч
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Модератор форума
У студентов как всегда богатая фантазия... :^(
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421712
Фотография Владимир Саныч
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Модератор форума
Это было Темному.

2 Serge Gavrilov:
А как из формы сослаться на объектную переменную, которая ссылается на эту форму? Сработает ли такое:

for each o in mycollection
if o.form is me then...
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421714
Фотография Serge Gavrilov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторМеняй ей Caption при открытии, а потом проверяй его на соответствие в For Each
Только как это поможет закрыть конкретную форму?
Все формы и так закрываются по по приведеному мной коду.
...
Рейтинг: 0 / 0
Как закрыть все открытые юзером формы через For Each ?
    #32421716
Фотография Темный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ну дай побуйствовать фантазии
А все формы можно и kill process msaccess закрыть :)
...
Рейтинг: 0 / 0
25 сообщений из 36, страница 1 из 2
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Как закрыть все открытые юзером формы через For Each ?
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]