Как "приджойнить" к динамическому списку таблицу из формы

19.07.23

Разработка - Работа с интерфейсом

Вывести в динамический список дополнительные колонки из таблицы на форме.

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

 

 

Для вывода значений из таблицы воспользовался событием 

&НаСервереБезКонтекста
ПриПолученииДанныхНаСервере(ИмяЭлемента, Настройки, Строки)

Проблема была как передать таблицу из формы на сервер без контекста - можно сохранить таблицу (точнее конвертации ее в соответствие или массив) или же можно поместить во временное хранилище и сохранить адрес таблицы в дополнительных свойствах настроек компоновщика данных динамического списка

&НаСервере
Процедура ПриджойнитьНаСервере()
.......................
//ТЗ - коллекция данных либо адрес в хранилице

СписокНоменклатуры.КомпоновщикНастроек.Настройки.ДополнительныеСвойства.Вставить("ТЗ", ТЗ);
		
Элементы.СписокНоменклатуры.Обновить();

КонецПроцедуры

При обновлении динамического списка срабатывает событие

&НаСервереБезКонтекста
Процедура СписокНоменклатурыПриПолученииДанныхНаСервере(ИмяЭлемента, Настройки, Строки)
	// Вставить содержимое обработчика.
	Если Настройки.ДополнительныеСвойства.Свойство("ТЗ") Тогда
		//получаем ТЗ
		
		Для каждого Стр Из Строки Цикл
			ДанныеСтроки = Стр.Значение.Данные;
			
			СтрокаТЗ = ТЗ.Найти(ДанныеСтроки.Номенклатура,"Номенклатура");
			
			Если СтрокаТЗ <> Неопределено Тогда
				 ДанныеСтроки.ДопПоле = СтрокаТЗ.ДопПоле;
			КонецЕсли;
			
		КонецЦикла;
	КонецЕсли;
КонецПроцедуры

Статья больше написана как шпаргалка для себя, но, может быть, кому-то будет полезна. 

лайфхак динамический список

См. также

Управление дашбордами

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    17196    23    4    

37

Новогоднее оформление для 1С

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    11683    776    elcoan    47    

108

Конструктор HTML, CSS и javascript

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Подходит для создания web-страниц для замены управляемых форм 1С, красивых отчетов, интерфейса мобильного приложения на платформе 1С и для простых страниц веб-сайтов.

2 стартмани

10.04.2023    10213    157    acces969    31    

120

Модель состояния для MVC

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    4210    kalyaka    4    

31

Условное оформление элементов форм в пользовательском режиме 1С (управление видимостью и доступностью элементов форм)

Работа с интерфейсом Платформа 1С v8.3 Платные (руб)

Подсистема условного оформления элементов форм (далее подсистема) предназначена для настройки оформления элементов форм (видимость, доступность, цвет фона, цвет текста и прочее) в пользовательском режиме 1С. Также подсистему возможно использовать для ограничения доступа к реквизитам формы для определенных пользователей (или групп пользователей).

6000 руб.

18.01.2022    9110    1    2    

6

Программный интерфейс для доработки форм

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Реализовал простой способ программного создания новых элементов, команд и реквизитов на форме.

25.11.2021    10018    AtamanovYS    19    

141
Оставьте свое сообщение