Программное создание колонок в табличной части документа и сохранение значений в этом же документе

13.12.24

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

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

Файлы

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

Наименование Скачано Купить файл
Программное создание колонки в документе ТЧ и сохранение значения в нем
.cf 308,31Kb
4 3 000 руб. Купить

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

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

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

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

1. В самом документе необходимо создать реквизит, например, с именем "ДанныеТабЧастьНоменклатура" с типом "ХранилищеЗначения". В этот реквизит и будут записываться значения из программно созданной колонки.

2. В форме документа создаем процедуру ПриСозданииНаСервере. В ней программно создаем колонку табличной части "Тест3" и типом "Число":

нРеквизиты = Новый Массив;
нРеквизиты.Добавить(Новый РеквизитФормы("Тест3", Новый ОписаниеТипов("Число"), "Объект.Номенклатура", "Тест3", Истина));
ЭтаФорма.ИзменитьРеквизиты(нРеквизиты);
	 
нЭлемент = Элементы.Добавить("Тест3", Тип("ПолеФормы"), Элементы.Номенклатура); 
нЭлемент.Вид = ВидПоляФормы.ПолеВвода; 
нЭлемент.ПутьКДанным = "Объект.Номенклатура.Тест3";

3. В форме документа создаем процедуру ПередЗаписьюНаСервере, с помощью которой и запишем в реквизит ДанныеТабЧастьНоменклатура саму программно созданную колонку табличной части "Тест3" и ее значения.

&НаСервере
Процедура ПередЗаписьюНаСервере(Отказ, ТекущийОбъект, ПараметрыЗаписи)

	ТекущийОбъект.ДанныеТабЧастьНоменклатура = Новый ХранилищеЗначения(Объект.Номенклатура.Выгрузить()); 	
	ТекущийОбъект.Записать();

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

4. После пункта номер 3 значения сотрутся из программной колонки "Тест3", но запишутся в реквизит ДанныеТабЧастьНоменклатура, чтобы обратно вернуть значения колонки на форму, используем следующий код:

&НаСервере
Процедура ПослеЗаписиНаСервере(ТекущийОбъект, ПараметрыЗаписи)
	
	ЭтотОбъект.Объект.Номенклатура.Загрузить(ТекущийОбъект.ДанныеТабЧастьНоменклатура.Получить()); 
	
КонецПроцедуры 

Все готово.

Тестирование проводилось на релизе платформы: 1С:Предприятие 8.3 (8.3.13.1690). Библиотека стандартных подсистем не требуется. 

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

См. также

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

31720 руб.

27.03.2025    76080    48    36    

59

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

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

36600 руб.

28.08.2025    6796    2    2    

6

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

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

6100 руб.

14.01.2016    59752    22    25    

47

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

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

6088 руб.

17.10.2025    1722    3    0    

2

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

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

20.08.2024    47839    mrXoxot    44    

138

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

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

27.05.2024    26032    smielka    38    

114

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

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

3 стартмани

10.04.2023    17265    180    acces969    31    

132
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 2136 13.12.24 22:41 Сейчас в теме
Уж если создавать реквизиты в расширении, то сразу в таб. части.
Для отправки сообщения требуется регистрация/авторизация