Взаимодействие окон в системе 1С:Предприятие

07.06.21

Разработка - Механизмы платформы 1С

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

Рассмотрим пример кода:

ТаблицаТоваров = ВыбратьТоварыАвтоматически(Склад);

В указанном примере функция "ВыбратьТоварыАвтоматически" выполняется синхронно. Т.е. пока работает функция, код далее не выполняется. Если функция работает долго, то мы должны будем ждать, пока она не закончит свою работу. Выполнять другие действия или прервать работу функции мы не можем.

Для того, чтобы обойти это ограничение, нужно выполнить функцию асинхронно:

&НаКлиенте
Процедура ВыбратьТовары(Команда)
	
	ОписаниеОповещения = Новый ОписаниеОповещения("ПослеВыбораТоваров", ЭтаФорма);
	ВыбратьТоварыАвтоматически(ОписаниеОповещения, Склад);
	
КонецПроцедуры

&НаКлиенте
Процедура ПослеВыбораТоваров(ТаблицаТоваров) Экспорт
		
КонецПроцедуры

 Приведенный пример будет работать так:

  1. Начать выполнять "Выбрать товары"
    (при этом дальнейшее выполнение кода не блокируется и наша система может работать дальше).
  2. Когда функция "Выбрать товары" завершит свою работу, будет вызвана процедура "ПослеВыбораТоваров"

Функция "ВыбратьТоварыАвтоматически" выполняет какие-то вычисления и возвращает результат.  Но что, если для получения результата необходимы действия пользователя. В этом случае необходимо разработать окно, в котором пользователь сможет "поработать" и вернуть результат.

Ниже приведено сравнение описания функции и окна:

 

 

В обоих случаях соблюдаются правила:

  1. Описываются параметры и результат.
  2. Вызывающая сторона не знает, как устроена функция (окно), которое вызывается.
  3. Функция (окно) не знают, кто их вызывает и как будет использован результат.

Теперь можно написать код, который будет выполнять выбор товаров с использованием окна "ВыборТоваров" вместо функции "ВыборТоваров".


 

Кратко и понятно, но, к сожалению, работать не будет.

Дело в том, что открыть окно и передать из одного окна в другое результат можно только на клиенте.

Таблица товаров - это таблица значений и она не может существовать на клиенте (тонкий клиент и веб-клиент не поддерживают таблицы значений).

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


 

Теперь можно еще немного усложнить задачу. Пусть необходимо из процедуры "ВыбратьТовары" в процедуру "ПослеВыбораТоваров" передать какие-то значения. Например, передадим признак необходимости очистить табличную часть перед добавлением выбранных товаров.

 

 

Вот и все.

 

Итого:

  1. Вызов одного окна из другого можно рассматривать как вызов функции.
    При разработке окна можно руководствоваться теми же принципами, что и при разработке функции: единственная цель, понятные параметры и результат и т.д.
  2. При необходимости передавать между окнами значения, которые не поддерживаются на клиенте, надо использовать временное хранилище.
  3. При необходимости предать параметры из процедуры открытия окна в процедуру обработки результата требуется использовать дополнительные параметры.

Вступайте в нашу телеграмм-группу Инфостарт

окна ВременноеХранилище ДополнительныеПараметры

См. также

Механизмы платформы 1С Программист Бесплатно (free)

Разберем 15 мифов о работе платформы «1С:Предприятие 8» – как распространенных, так и малоизвестных. Начнем с классики: «Код, написанный в одну строку, работает быстрее, чем многострочный». Так ли это на самом деле?

16.07.2025    26813    TitanLuchs    106    

146

Механизмы платформы 1С Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

Про ООП в 1С и о том, как сделать свой код более кратким и выразительным при помощи использования текучего интерфейса (fluent interface).

03.02.2025    14813    bayselonarrend    127    

68

Механизмы платформы 1С Программист 1С:Предприятие 8 Бесплатно (free)

В этой статье подробно рассматривается работа с JSON в XDTO в 1С:Предприятие. Вы узнаете, как сериализовать и десериализовать объекты XDTO в JSON, интегрировать 1С с веб-сервисами и API, а также корректно обрабатывать данные при обмене. Разбираются особенности работы с коллекциями, использование функций восстановления и частые ошибки при работе с JSON и XDTO.

30.01.2025    16422    user2122906    9    

60

Механизмы платформы 1С WEB-интеграция Программист 1С:Предприятие 8 Бесплатно (free)

В платформе 8.3.27 появилась возможность использовать WebSocket-клиент. Давайте посмотрим, как это все устроено и чем оно нам полезно.

14.01.2025    26919    dsdred    77    

143

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Эта небольшая статья - некоторого рода шпаргалка по файловым потокам: как и зачем с ними работать, какие преимущества это дает.

23.06.2024    24756    bayselonarrend    22    

175

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    13613    dsdred    22    

85
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 2097 07.06.21 11:44 Сейчас в теме
Функция (окно) не знают, кто их вызывает и как будет использован результат.
Правда только частично. На клиенте есть свойство ВладелецФормы, так что окно знает, кто его вызвал.
2. Gladkov_Anton 359 07.06.21 14:13 Сейчас в теме
(1)
результат


С точки зрения проектирования взаимодействия окон обращение вида "ВладелецФормы.Объект.Склад" хоть и будет работать, но делать так не следует. Это порождает не очевидные связи, которые потом не понятно как отслеживать, если например реквизит "Склад" переименуют.

Правильным все таки является проектирование взаимодействия при которых известны только параметры и результат.

Есть еще "Оповещения", но работа с ними находятся за пределами этой статьи.
3. ixijixi 2097 07.06.21 14:25 Сейчас в теме
(2)
делать так не следует
С этим согласен, но бывают ситуации, когда без этого не обойтись. Например, создание внешней обработки заполнения объекта. Без обращения к ВладелецФормы.Объект ничего не сделаешь.
Для отправки сообщения требуется регистрация/авторизация