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

07.06.21

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

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

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

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

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

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

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

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

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

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

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

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

 

 

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

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

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


 

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

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

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

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


 

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

 

 

Вот и все.

 

Итого:

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

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

См. также

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

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

03.02.2025    6022    bayselonarrend    126    

59

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

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

14.01.2025    7804    dsdred    57    

99

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

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

23.06.2024    11522    bayselonarrend    21    

162

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

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

13.03.2024    7854    dsdred    18    

82

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

Все мы используем массивы в своем коде. Это один из первых объектов, который дают ученикам при прохождении обучения программированию. Но умеем ли мы ими пользоваться? В этой статье я хочу показать все методы массива, а также некоторые фишки в работе с массивами.

24.01.2024    27075    YA_418728146    33    

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


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

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

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