Визуализация таблицы значений на управляемой форме

02.11.22

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

Данная публикация описывает способ отражения на управляемой форме таблицы значений, с произвольным составом колонок, полученной на сервере. Как частный случай рассматривается отражение двумерного массива, с преобразованием его в таблицу значений.

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

Посмотрим, как это можно сделать:

Я покажу оба способа:

  • Визуализация двумерного массива
  • Визуализация ТЗ

Первый вариант включает в себя второй.

Допустим, мы имеем на клиенте двумерный массив. В данном случае, это  массив с данными, прочитанный по API с нашего известного маркетплейса.

&НаКлиенте
МассивСДанными = ПрочитатьJSON(ЧтениеJSON);
Если ТипЗнч(МассивСДанными) = Тип("Массив") Тогда	
		СоздатьИЗаполнитьСтруктуруКолонок(МассивСДанными); //ВЫзов основной серверной процедуры

Нам нужно его визуализировать на форму, (с последующей естественно обработкой), но в моменте нужно визуально просмотреть: а что там JSON собственно начитал.

  1. Создадим на форме реквизит «ТЗ_ЧтениеJSON». Без колонок реквизитов.  

Нюанс: Реквизит - таблицу можно создавать и динамически (далее я укажу этот вариант в коде). Но я считаю, что реквизит будущей таблицы удобнее разместить сразу в форме там, где нужно и как нужно.

 

 

  1. Если мы работаем с массивом,  то имеет смысл преобразовать его в ТЗ с помощью известной функции. Если мы уже имеем ТЗ, то  переходим сразу к пункту 3
    &НаСервере
    Функция ПреобразованиеМассивВТаблицуЗначений(Массив)
    	
    	ТЗ = Новый ТаблицаЗначений;
    	
    	Для Каждого СтрокаМассива Из Массив Цикл
    		
    		Если ТЗ.Колонки.Количество() = 0 Тогда
    			Для Каждого ЭлементМассива Из СтрокаМассива Цикл
    				ТЗ.Колонки.Добавить(ЭлементМассива.Ключ);
    			КонецЦикла;
    		КонецЕсли;
    		
    		НоваяСтрока = ТЗ.Добавить();
    		Для Каждого ЭлементМассива Из СтрокаМассива Цикл
    			НоваяСтрока[ЭлементМассива.Ключ] = ЭлементМассива.Значение;
    		КонецЦикла;
    	КонецЦикла;
    	
    	Возврат ТЗ;
    	
    КонецФункции
    

     

  2.  Ну и собственно серверная процедура, создающая таблицу на форме и заполняющая ее данными из ТЗ. 
Процедура СоздатьИЗаполнитьСтруктуруКолонок (МассивСДанными)
	
	//Получаем ТЗ из массив (или откуда угодно)
	//Помним что ТЗ живет у нас только на сервере !!!
	ТЗ = ПреобразованиеМассивВТаблицуЗначений(МассивСДанными);
	
	МассивКолонок = Новый Массив;    
	
	//-------------Если элемент таблица создается динамически на форме--------
	//МассивКолонок.Добавить(Новый РеквизитФормы("ТЗ_ЧтениеJSON",Новый ОписаниеТипов("ТаблицаЗначений")));  
    //- она кстати тоже будет элементом  массива
	//-------------Если элемент таблица создается динамически на форме-------
	
	//Добавим колонки в существующий реквизит формы
	Для Каждого КолонкаТЗ ИЗ ТЗ.колонки Цикл
		ИмяКолонки = КолонкаТЗ.Имя; 
 
		ТипРеквизита = Новый ОписаниеТипов("Строка", , ,Новый КвалификаторыСтроки(150)); //Тут можно типизировать колонку реквизита явным образом , но в моем случае это строка и делать я этого не буду
		нРеквизитФормы = Новый РеквизитФормы(ИмяКолонки, ТипРеквизита, "ТЗ_ЧтениеJSON", ИмяКолонки); //Новый реквизит - элемент массива
		Если ЭтаФорма.Элементы.Найти(ИмяКолонки) = Неопределено  Тогда //ищем в составе элеменов формы, чтобы при повторном вызове процедуры не было ошибки задвоения реквизитов	
			МассивКолонок.Добавить(нРеквизитФормы);   
		КонецЕсли;
	КонецЦикла;
	
	// добавим собственно реквизиты на форму
	ИзменитьРеквизиты(МассивКолонок);
	
	//-------------Если элемент таблица создается динамически на форме-------
	//// добавим элементы формы
	//Таб = Элементы.Добавить("ТЗ_ЧтениеJSON", Тип("ТаблицаФормы"));
	//Таб.ПутьКДанным = "ТЗ_ЧтениеJSON";
	
	//// запретим менять положение строк и сами строки, отключим командную панель
	//Таб.ИзменятьСоставСтрок = Ложь;
	//Таб.ИзменятьПорядокСтрок = Ложь;
	//Таб.ПоложениеКоманднойПанели = ПоложениеКоманднойПанелиЭлементаФормы.Нет;
	//-------------Если элемент таблица создается динамически на форме-------
	
	//Добавим поля и пропишем путь к данным
	Для Каждого КолонкаТЗ ИЗ ТЗ.колонки Цикл
		ИмяКолонки = КолонкаТЗ.Имя;
		Если ЭтаФорма.Элементы.Найти(ИмяКолонки) = Неопределено  Тогда	
			нЭлемент = Элементы.Добавить(ИмяКолонки, Тип("ПолеФормы"), Элементы.ТЗ_ЧтениеJSON); 
			нЭлемент.Вид = ВидПоляФормы.ПолеВвода; 
			нЭлемент.ПутьКДанным = "ТЗ_ЧтениеJSON." + ИмяКолонки;
		КонецЕсли;
	КонецЦикла;
	
	ТЗ_ЧтениеJSON.Загрузить(ТЗ); //Грузим нашу исходную ТЗ  
	
КонецПроцедуры	

 

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

таблица значений на управляемой форме

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

29280 руб.

27.03.2025    68953    41    29    

54

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36600 руб.

28.08.2025    5360    2    2    

5

Консолидация данных Работа с интерфейсом Программист Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 1C:ERP Узбекистан Беларусь Кыргызстан Россия Казахстан Платные (руб)

Знакомая ситуация? Пользователи, особенно менеджеры, уверены: отборов много не бывает. Идут пожелания добавить в форму списка еще один быстрый фильтр, еще два, еще пять... В итоге интерфейс превращается в нагромождение полей отбора, а потребность в «самом главном» отборе, который «вот прямо сейчас нужен», все равно не закрыта. Универсальное расширение, которое решает эту проблему элегантно и технологично. С его помощью в любую форму списка можно легко добавить панель настраиваемых кнопок-закладок, каждая из которых применяет сложный фильтр-запрос, а так же показывает актуальное количество элементов в реальном времени.

6088 руб.

17.10.2025    1403    3    0    

2

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

Расширение «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

6100 руб.

14.01.2016    59262    21    25    

46

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

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

5246 руб.

29.06.2020    23570    33    6    

52

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

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

21.05.2024    50424    dimanich70    83    

170

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

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

28.08.2023    24120    YA_418728146    8    

174

Пакетная печать Печатные формы Адаптация типовых решений Универсальные функции 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Абонемент ($m)

Расширение для программ 1С:Управление торговлей, 1С:Комплексная автоматизация, 1С:ERP, которое позволяет распечатывать печатные формы для непроведенных документов. Можно настроить, каким пользователям, какие конкретные формы документов разрешено печатать без проведения документа.

2 стартмани

22.08.2023    8229    114    progmaster    22    

6
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. WorkerPavel 02.11.22 13:54 Сейчас в теме
С такой картинкой вас посодют за дискредитацию вооружённых сил РФ.

А если по теме то у вас форматирование сбилось в 3 пункте:
Прикрепленные файлы:
2. DMon 120 07.11.22 11:40 Сейчас в теме
А я плюсану за такую картинку! )
Для отправки сообщения требуется регистрация/авторизация