Программное создание элементов в форме при использовании расширения

19.05.24

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

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

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

Сам стараюсь в расширениях изменения в конструкторе форм не практиковать. Но встречаюсь с таким часто. Не исключение, когда у заказчика есть (или было) несколько подрядчиков. И каждый ведет собственное расширение. Чтобы не делить ответственность. Как следствие - изменение одних и тех же объектов в разных расширениях, под разные задачи, не редкое явление.

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

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

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

//infostart.ru/1c/articles/1118319/?ysclid=lta3h29kir838274485#_Toc18589857

 

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

Конечно, никакого прямого запрета нет. Изменения в конструкторе не запрещены. Никаких нехороших последствий немедленно не наступает. Но со временем и ростом количества расширений это превращается в раздражающую проблему. И для Вас и для других участников разработки. Добавляя Вам их проклятия в карму. Оно Вам надо?

Концентрация же новых реквизитов и элементов в процедуре формы "ПриСозданииНаСервере" делает Ваши изменения более понятными и легко обнаруживаемыми. И более устойчивыми к обновлению формы.

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

Для демонстрации методики использования фукций модуля я сделал простую обработку. Вы сами можете ее повторить. Просто создайте новую обработку с формой. И поместите следующие тексты в модуль обработки и модуль формы. Не забудьте назначить в форме обработчик события "ПриСозданииНаСервере".

 
 Текст модуля обработки
 
 Текст модуля формы
&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
	
	Обработка = РеквизитФормыВЗначение("Объект"); 
	
	//Описываем типы
	ТипЧисло = Новый ОписаниеТипов("Число", , , Новый КвалификаторыЧисла(10, 2));
	ТипСтрока = Новый ОписаниеТипов("Строка", , , , Новый КвалификаторыСтроки(1000));
	ТипДата = Новый ОписаниеТипов("Дата", , , , , Новый КвалификаторыДаты(ЧастиДаты.ДатаВремя));
	ТипБулево = Новый ОписаниеТипов("Булево");
	ТипДополнительноеЗначение = Новый ОписаниеТипов("СправочникСсылка.ЗначенияСвойствОбъектов");
	
	//Создаем новую группу страниц и страницу
	ГруппаСтраниц = Обработка.СоздатьГруппу(ЭтотОбъект, ВидГруппыФормы.Страницы, "ГруппаСтраниц", ЭтотОбъект);
	ГруппаСтраница = Обработка.СоздатьГруппу(ЭтотОбъект, ВидГруппыФормы.Страница, "ГруппаСтраница", ГруппаСтраниц, "Демонстрация", ГруппировкаПодчиненныхЭлементовФормы.ГоризонтальнаяВсегда); 
	
	//Создаем две обычные группы
	ГруппаЛево = Обработка.СоздатьГруппу(ЭтотОбъект, ВидГруппыФормы.ОбычнаяГруппа, "ГруппаЛево", ГруппаСтраница); 
	ГруппаПраво = Обработка.СоздатьГруппу(ЭтотОбъект, ВидГруппыФормы.ОбычнаяГруппа, "ГруппаПраво", ГруппаСтраница);
	
	//Создаем поля и реквизиты простых типов
	Обработка.СоздатьПолеСРеквизитом(ЭтотОбъект, "РеквизитЧисло", ТипЧисло, ГруппаЛево, "Поле число");
	Обработка.СоздатьПолеСРеквизитом(ЭтотОбъект, "РеквизитСтрока", ТипСтрока, ГруппаПраво, "Поле строка");
	Обработка.СоздатьПолеСРеквизитом(ЭтотОбъект, "РеквизитДата", ТипДата, ГруппаЛево, "Поле дата");
	Обработка.СоздатьПолеСРеквизитом(ЭтотОбъект, "РеквизитФлаг", ТипБулево, ГруппаЛево, "Флаг", ВидПоляФормы.ПолеФлажка); 
	
	//Создаем тестовое свойство, поле и реквизит для ввода дополнительных значений
	ИмяДополнительногоСведения = "ДополнительноеСвойствоТест";
	Свойство = Обработка.ПолучитьСоздатьСвойство(ИмяДополнительногоСведения, ТипДополнительноеЗначение, , , , "Дополнительное свойство");
	Обработка.СоздатьПолеДопЗначения(ЭтотОбъект, ИмяДополнительногоСведения, ГруппаЛево, Свойство.Наименование); 
	
	//Создаем кнопку привет
	Обработка.СоздатьКнопку(ЭтотОбъект, "КомандаПоказатьСтроку", ГруппаПраво, "Показать строку");
	
	//Создаем свертываемую группу и создаем и заполняем поле картинки
	ГруппаКартинка = Обработка.СоздатьГруппу(ЭтотОбъект, ВидГруппыФормы.ОбычнаяГруппа, "ГруппаКартинка", ГруппаЛево, "Картинка", , ПоведениеОбычнойГруппы.Свертываемая, Ложь);
	Обработка.СоздатьПолеСРеквизитом(ЭтотОбъект, "АдресКартинки", ТипСтрока, ГруппаКартинка, , ВидПоляФормы.ПолеКартинки);
	Картинка = БиблиотекаКартинок.Календарь;
	ЭтотОбъект.АдресКартинки = ПоместитьВоВременноеХранилище(Картинка.ПолучитьДвоичныеДанные());
	Элементы.АдресКартинки.РазмерКартинки = РазмерКартинки.Пропорционально;
	 
КонецПроцедуры

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

 

 

Запускаем и убеждаемся в работоспособности кода. Результат должен быть примерно такой:

 
 Результат запуска обработки

 

Картинка свертывается. Кнопка работает. 

 
 Работа формы

 

 

Убедившись что работает, код модуля обработки можно перенести в общий модуль. Например, свой. Или тематический.

В форме обработки имеем примеры вызова функций модуля для быстрого создания основных типов полей.

Лично я пользуюсь с удовольствием. Чего и Вам желаю.

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

Как-то так.

Удачного плавания. Надеюсь, что прочитав это, кто-то будет меньше изменять формы в конструкторе.

Расширение управляемая форма программное создание элемент формы БСП конструктор форм приемы разработка

См. также

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

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

5000 руб.

14.01.2016    55301    17    23    

43

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

Богатый редактор картинок 1С предназначен для обработки изображений в режиме «Предприятие», с возможностью РИСОВАТЬ на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6000 руб.

16.01.2015    63692    44    59    

82

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

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

2400 руб.

29.06.2020    19547    27    6    

42

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

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

1500 руб.

06.10.2020    10763    7    7    

11

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

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

20.08.2024    20803    mrXoxot    44    

128

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

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

27.05.2024    10285    smielka    37    

105

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

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

27.12.2023    17735    1223    elcoan    53    

125
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. yuha33 05.03.24 09:05 Сейчас в теме
Я прошел через такое. Ничего кроме головной боли программное создание элементов не принесло.
user872840; +1 Ответить
2. KVIKS 429 05.03.24 09:51 Сейчас в теме
(1)На вкус и цвет - все фломастеры разные.
Я приловчился с программными элементами и проблем это не вызывает.
Рамзес; NeLenin; +2 Ответить
3. ixijixi 1975 05.03.24 11:13 Сейчас в теме
Небольшая ремарка насчет процедуры СоздатьРеквизит. Рекомендуется создавать и удалять все реквизиты одним махом, т.к. операция считается очень затратной по ресурсам.

СП
Действия добавления и удаления выполняются за один вызов.
Следует учитывать, что операция изменения состава реквизитов является ресурсоемкой,
поэтому операции изменения состава реквизитов формы выполняются
пакетным образом.
Рамзес; M.Nikitin; NeLenin; ivprovotorov; shard; 0x00; +6 Ответить
6. user1374747 239 05.03.24 15:24 Сейчас в теме
(3)Привет. Знаю ли я об этом? Да знаю.

Здесь вопрос целей и места действия.
Для моих целей на тонком клиенте торможения не заметил.
На web возможно, это критично. Не проверял.
Главная цель была отучить изменять формы в расширении конструктором.

Можно заслать в функцию массив имен. Но тогда функция станет труднее в понимании и использовании.
Т.е. получив мнимый плюс - получает ощутимый минус для главной цели.
Стоит ли оно того?

Извиняюсь, если у кого то другие приоритеты. Если человек займется программным созданием, то он разберется, со временем. Ссылку на шпаргалку я дал. Но каждому овощу свой срок. Главное - чтобы занялся.
4. user1950534 05.03.24 11:32 Сейчас в теме
Программное создание визуальных элементов в любом аналогичном фреймворке - зло злющее, об этом все говорят и пишут.

Да, оно вроде как удобно и понятно но только тому, кто разрабатывает эту шнягу изначально!

А попробуй потом найди, где хайдится кнопель в каком модуле и в каком обработчике.
Кто-то любит "ПриОткрытии", другой "ПриСозданииНаСервере", третий вообще - подписку на событие.
Да и запрятать заветный код где-то в 4м уровне стека вызова, как водится....
Trucker; Award; bulpi; _alex1974; vakham; user872840; +6 2 Ответить
5. starik-2005 3096 05.03.24 11:37 Сейчас в теме
(4)
об этом все говорят и пишут
А ссылки есть на всех?
ЗЫ: Остальные проблемы возникают и без создания программного. Вот, например, эксель. Вроде бы что там такого, да? Но есть, например, выделение цветом по условию - первый раз долго искал.
Рамзес; NeLenin; +2 Ответить
7. user1374747 239 05.03.24 15:32 Сейчас в теме
(4)Очень понимаю. Когда то программное создание меня тоже раздражало.

Казалось бы. Милое дело - зашел в конструктор и все увидел.

А то возись изучая малознакомый код.

Но со временем код перестал быть малознакомым.
Зато столкнулся с изменением формы сразу в четырех расширениях.
Честно говоря, тоже забодался разыскивать визуально все изменения.
Еще и группы норовят интерактивно вставить.

То ли дело - просто объединить код "ПриСозданииНаСервере" в одной форме главного расширения.

Поэтому все зависит от того, с какой колокольни смотреть. У каждого свой жизненный опыт.
Рамзес; NeLenin; +2 Ответить
15. FarFar 47 22.07.24 10:59 Сейчас в теме
(4) другой разработчик уж абсолютно точно заглянет в модуль формы в расширении, и увидит программное создание элемента.
8. dima_gsv 23 06.03.24 08:58 Сейчас в теме
Мы используем программное создание элементов для доработки форм основной конфигурации, которая обновляется поставщиком. Этим мы решаем две задачи:
1. упрощается обновление формы, если поставщик её сильно изменил,
2. не требуется добавлять реквизит формы "Объект" в расширение, из-за чего в расширение паровозиком "заезжает" куча ненужных реквизитов объектов.
Рамзес; +1 Ответить
9. user1374747 239 06.03.24 17:03 Сейчас в теме
(8)

Ну да.

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

Статья для тех, кто самостоятельно принимает решение как поступать. Никто же не смотрит. И никто не наругает.
Она о том, как и в скорости не проиграть и другим проблем не создать.
Сохранив карму.
10. rpgshnik 3815 07.03.24 12:44 Сейчас в теме
Рад, что понравилась шпаргалка, ещё есть большая библиотека со схожим функционалом https://infostart.ru/1c/articles/1284403/
11. user1374747 239 07.03.24 16:39 Сейчас в теме
(10)
Тоже рад. Что есть такое подспорье. И что есть люди, которые не ленятся его делать.
12. lvictor58 138 11.03.24 15:39 Сейчас в теме
Я так понимаю, что все это (программное создание реквизитов) имеет смысл если мы не тянем в расширение саму форму. В таком случае прописать создание можно только в общем модуле. В ЕРП я использую для этих целей процедуру
МодификацияКонфигурацииПереопределяемый.ПриСозданииНаСервере(Форма, Отказ, СтандартнаяОбработка)
13. user1374747 239 11.03.24 17:19 Сейчас в теме
(12)
Привет.
Нет. Именно тянем. Просто в конструкторе ничего не добавляем.
Добавляем код в процедуре "ПриСозданииНаСервере".
Чтобы потом не было проблем с обновлением или потерей функционала при переносе в другое расширение.
Актуально для конфигураций, которые на замке. И в расширения которых разные люди лезут из разных контор.
Я последнее время работаю, главным образом, в облаке. Там это очень распространенное явление.
Рамзес; +1 Ответить
16. FarFar 47 22.07.24 11:02 Сейчас в теме
(12) тянем форму, но визуально ничего в ней не меняем. Делаем наши программные вставки в модуле формы
14. user2065162 12.03.24 16:15 Сейчас в теме
Просто создайте новую обработку с формой. И поместите следующие тексты в модуль обработки и модуль формы.

А также назначьте обработчик события "ПриСозданииНаСервере".
Оставьте свое сообщение