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

15.08.19

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

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Обновление данных в ячейках таблицы формы на управляемых формах:
.epf 6,57Kb ver:1.0
0
0 Скачать (1 SM) Купить за 1 850 руб.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

См. также

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

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

5000 руб.

14.01.2016    55614    17    23    

43

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

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

2400 руб.

29.06.2020    19930    28    6    

44

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

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

20.08.2024    23397    mrXoxot    44    

130

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

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

27.05.2024    11936    smielka    37    

105

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

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

27.12.2023    18337    1228    elcoan    53    

125

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

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

3 стартмани

10.04.2023    12878    167    acces969    31    

126

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

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

1 стартмани

05.07.2022    7940    kalyaka    6    

33

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

Ещё с времен платформы 8.3.13 можно изменять цвет стилей интерфейса главного окна. Данное расширение позволит вам выбрать из подготовленных десятка стилей на свой вкус.

1 стартмани

01.07.2022    26844    423    rpgshnik    69    

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

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

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