Модуль объекта в 1С 8.3

Mar 27, 2022 21:36

Модуль объекта

Модуль объекта есть почти у всех основных прикладных объектов конфигурации в 1С.

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

Чтобы открыть модуль объекта нужно в окне свойств объекта на закладке «Прочее» нажать кнопку «Модуль объекта»

Также модуль объекта можно открыть из контекстного меню объекта:

Или из меню Действия:

Модуль объекта выполняется при создании объекта. В нем можно объявлять переменные модуля. Экспортные процедуры и функции можно вызывать у созданных программных объектов. К экспортным переменным можно обращаться как к свойствам программных объектов. В модуле есть прямой доступ к реквизитам и табличным частям объекта.

Вызов методов модуля объекта

Для примера создадим в конфигурации справочник «Номенклатура» с реквизитом «Артикул» и табличной частью «Остатки». У табличной части будет 2 реквизита: «Склад» и «Остаток»:

В модуле объекта напишем следующий код:

//переменные
Перем ОбщийОстаток Экспорт;
Перем ПолноеНаименование;

//процедуры и функции
Функция ПолноеНаименованиеНоменклатуры()
Возврат "Системный блок в сборе";
КонецФункции

Функция ОбщийОстаток() Экспорт
Возврат 300;
КонецФункции

Процедура ЗаполнитьРеквизиты() Экспорт
Артикул = "Арт1";

НовСтр = Остатки.Добавить();
НовСтр.Склад = "Основной";
НовСтр.Остаток = 100;

НовСтр = Остатки.Добавить();
НовСтр.Склад = "Торговый зал";
НовСтр.Остаток = 200;
КонецПроцедуры

Теперь создадим обработку с одной формой и в модуле обработки в событии ПриСозданииНаСервере напишем следующий код:

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
//программно создаем новый элемент справочника
ОбъектНоменклатура = Справочники.Номенклатура.СоздатьЭлемент();
//заполняем экспортную переменную модуля объекта вызвав экспортную функцию
ОбъектНоменклатура.ОбщийОстаток = ОбъектНоменклатура.ОбщийОстаток();
Сообщить(ОбъектНоменклатура.ОбщийОстаток); //300
КонецПроцедуры

Здесь мы сначала создаем новый программный объект справочника Номенклатура вызвав встроенный метод Справочники.Номенклатура.СоздатьЭлемент(). Потом через ссылку на этот объект обращаемся к экспортным переменной и функции объекта.

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

Теперь поменяем код в модуле формы обработки на следующий:

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
//программно создаем новый элемент справочника
ОбъектНоменклатура = Справочники.Номенклатура.СоздатьЭлемент();
//пытаемся заполнить переменную модуля объекта вызвав функцию модуля объекта
ОбъектНоменклатура.ПолноеНаименование = ОбъектНоменклатура.ПолноеНаименованиеНоменклатуры();
Сообщить(ОбъектНоменклатура.ПолноеНаименование); //ошибка
КонецПроцедуры

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

При открытии формы возникнет ошибка «Поле объекта не обнаружено ПолноеНаименование»:

Так как переменная ПолноеНаименование не является экспортной, то к ней нет доступа из других модулей.

Теперь попробуем обратиться к не экспортной функции модуля объекта. Вставим в модуль формы следующий код и откроем обработку:

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
//программно создаем новый элемент справочника
ОбъектНоменклатура = Справочники.Номенклатура.СоздатьЭлемент();
//просто вызовем функцию модуля объекта
Сообщить(ОбъектНоменклатура.ПолноеНаименованиеНоменклатуры()); //опять ошибка
КонецПроцедуры

Выйдет ошибка «Метод объекта не обнаружен ПолноеНаименованиеНоменклатуры»:

Теперь вставим в форму обработки такой код и откроем обработку:

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
//программно создаем новый элемент справочника
ОбъектНоменклатура = Справочники.Номенклатура.СоздатьЭлемент();
//вызовем экспортную процедуру модуля объекта
ОбъектНоменклатура.ЗаполнитьРеквизиты();
//запишем объект в базу данных
ОбъектНоменклатура.Записать();
КонецПроцедуры

Здесь мы вызываем экспорную процедуру модуля объекта, а потом встроенным методом Записать записываем объект в базу данных.

В результате в базе данных будет создан новый элемент, у которого заполнен артикул и добавлены 2 строки в табличную часть:

В методе ЗаполнитьРеквизиты() мы обращались напрямую к реквизитам объекта, после чего записали его методом Записать(). Значения реквизитов сохранились в базе данных.

Обработчики событий

В модуле объекта есть множество различных обработчиков событий, которые вызываются в определенные моменты времени. Чтобы увидеть все события нужно нажать на кнопку «Процедуру и функции» в панели инструментов:

В результате откроется список возможных событий:

Если выделить какое-то событие и нажать кнопку «Перейти» или просто щелкнуть по нему два раза левой кнопкой мыши, то в модуле объекта будет создана процедура для обработки данного события.

Рассмотрим основные события модуля объекта:

* ОбработкаЗаполнения - выполняется при интерактивном создании нового объекта, при вводе на основании, при вызове метода Заполнить().
* ОбработкаПроверкиЗаполнения - выполняется перед записью объекта в базу данных, но до начала транзакции записи. Можно отказаться от записи, установив Отказ = Истина;
* ПередЗаписью - выполняется до записи объекта в базу данных, но после начала транзакции записи. Можно отказаться от записи, установив Отказ = Истина;
* ПриЗаписи - выполняется после записи объекта в базу данных, транзакция записи еще не зафиксирована. Все еще можно отказаться от записи.
* ПередУдалением - выполняется перед непосредственным удалением объекта из базы данных.
* ПриКопировании - выполняется при создании нового объекта копированием.

Для примера создадим в модуле объекта 3 обработчика события и вставим в них следующий код:

Процедура ОбработкаЗаполнения(ДанныеЗаполнения, ТекстЗаполнения, СтандартнаяОбработка)
Артикул = "Артикул";
КонецПроцедуры

Процедура ПередЗаписью(Отказ)
НовСтр = Остатки.Добавить();
НовСтр.Склад = "Основной";
НовСтр.Остаток = 50;
КонецПроцедуры

Процедура ПриЗаписи(Отказ)
НовСтр = Остатки.Добавить();
НовСтр.Склад = "Ордерный";
НовСтр.Остаток = 90;
КонецПроцедуры

Создадим интерактивно новый элемент справочника. Поле артикул уже будет заполнено:

Произвольно заполним наименование и нажмем на кнопку «Записать». В табличной части появятся 2 строки с остатками:

Одна строка была добавлена в событии ПередЗаписью, вторая ПриЗаписи.

Смотрите также:
Электронный учебник по по программированию в 1С
Рекомендации по изучению программирования 1С с нуля
Программное решение для сдачи и подготовки к экзаменам
Программирование в 1С 8.3 с нуля - краткий самоучитель
Комплексная подготовка программистов 1С:Предприятие 8.2
Сайты с уроками программирования и со справочниками
Youtube-каналы с уроками программирования
Сайты для обучения программированию
Лекции и уроки

программирование

Previous post Next post
Up