Обновление данных в ячейках таблицы формы на управляемых формах

15.08.19

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

На очередном проекте решал задачу по расчету значений колонок в табличных полях формы. Задача казалась достаточно простой. Однако возникла необходимость работать не только с реквизитами формы типа «ТаблицаЗначений», но и с типом «ДеревоЗначений». Релиз платформы 8.3.13.1644

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Обновление данных в ячейках таблицы формы на управляемых формах:
.epf 6,57Kb ver:1.0
1 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

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

Оформить подписку и скачать решение со скидкой

Используя механизмы работы с контекстом формы и преобразованием клиентского контекста данных формы в прикладные типы, с которыми можно выполнять любые действия, все получается. Сейчас писал про РеквизитФормыВЗначение() на серверной стороне. На клиенте, естественно, эта функция не работает.

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

В результате:

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

Делал через СКД с построением готовых макетов и выводом результата на форму. Этот метод ресурсоемок и достаточно длительный. На больших данных выполняется медленно. И не все задачи решаются при использовании СКД без использования вставок кода. Опять же переформирование визуальной части.

В итоге нашел достаточно простое решение. Использование клиентского метода ПолучитьЭлементы(). Следует учитывать, что при использовании такого подхода не работают такие фишки как например, НайтиСтроки().

Тем не менее перебор и работа со строками становятся куда приятнее. А пользователи пищат от удовольствия, потому что работа становиться как в "Excel".

Пример кода, как собрать сумму подчиненных в дереве. Работает, естественно, только при изменении самых нижних веток дерева.

&НаКлиенте
Процедура ДеревоЦенаПриИзменении(Элемент)
	
	ТекущаяСтрока = Элементы.Дерево.ТекущиеДанные;
	ТекущаяСтрока.Сумма = ТекущаяСтрока.Количество * ТекущаяСтрока.Цена;
	ОбновитьСуммыДереваНаКлиенте();
	
КонецПроцедуры

&НаКлиенте
Процедура ОбновитьСуммыДереваНаКлиенте ()
	
	тЭлементы = Дерево.ПолучитьЭлементы();
	Для каждого тЭлемент Из тЭлементы Цикл
		ОбновитьСуммуЭлементаФормыСтрокаКоллекцииДереваНаКлиенте(тЭлемент);
	КонецЦикла;
	
КонецПроцедуры

//Рекурсивная процедура обсчета строки
&НаКлиенте
Процедура ОбновитьСуммуЭлементаФормыСтрокаКоллекцииДереваНаКлиенте(ТекущаяСтрока)
	
	тЭлементы = ТекущаяСтрока.ПолучитьЭлементы();
	
	Если тЭлементы.Количество() > 0 Тогда
		ТекущаяСтрока.Сумма = 0;
		Для каждого тЭлемент Из тЭлементы Цикл
			ОбновитьСуммуЭлементаФормыСтрокаКоллекцииДереваНаКлиенте(тЭлемент);
			ТекущаяСтрока.Сумма = ТекущаяСтрока.Сумма + тЭлемент.Сумма;
		КонецЦикла;
	КонецЕсли;
	
КонецПроцедуры

Как поведет себя на больших объемах, пока не знаю. Не проверял. На 100 строках в таблице работает достаточно шустро. Видим прямую зависимость от мощей клиентского компьютера, т.к. все вычисления/переборы делаются именно на клиентской стороне. Более сложные расчеты, скорее всего, стоит перегонять в прикладные типы и передавать на сервер, для дальнейшего обсчета.

Обработка с примером реализации во вложении. Тестировалось на платформе 8.3.13.1644

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

Обработка КоллекцияСтрокДереваПоляФормы Обсчет таблицы

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С v8.3 8.3.14 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"!

28800 руб.

27.03.2025    53141    29    24    

42

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

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

5160 руб.

29.06.2020    22704    32    6    

50

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

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

5040 руб.

06.10.2020    12698    8    8    

14

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

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

20.08.2024    42367    mrXoxot    44    

138

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

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    24600    smielka    38    

111

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

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

27.12.2023    22672    1334    elcoan    53    

130

Инструментарий разработчика Работа с интерфейсом Программист 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    16118    178    acces969    31    

132
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. German_Tagil 43 16.08.19 05:49 Сейчас в теме
Ставлю +. Должно пригодиться
2. Yashazz 4885 16.08.19 20:01 Сейчас в теме
ребятушки, а можно не выкладывать примитив от начинающих?.. ну невозможно же просто...
Я могу порадоваться за новичков, открывших для себя азы программирования. Но зачем этим мусорить на ИС? Это же сайт "профессиональной", если не ошибаюсь, разработки...

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

...не, ну просто жесть. Ну давайте я расскажу, как выборку из справочника получить? Пацаны-то, походу, не знают!)
gravitator; asg.aleks; rpgshnik; +3 Ответить
Для отправки сообщения требуется регистрация/авторизация