СоздатьМенеджерЗначения()
//Пример: Вывести значения всех констант, существующих в конфигурации
Для Каждого ОчереднаяКонстанта Из Константы Цикл
ИмяКонст=ОчереднаяКонстанта. СоздатьМенеджерЗначения().Метаданные().Имя-ЗначениеКонст = ОчереднаяКонстанта. Получить(); Сообшить("Константа "+ИмяКонст+" = "+ЗначениеКонст); КонецЦикла;

II .<имя константы> // [<имя константы>] // Для Каждого... Из... Цикл... КоненЦикла;
//Пример: Прочитать значение константы
Результат = Константы. ПрефиксНумерации. ПолучитьО; Сообщить("Значение константы ПрефиксНумерации = "+Результат);
/ЛТример: Установить значение константы «ПрефиксНумерации» равным «ЦБ»
Константы["ПрефиксНумерации"].Установить("ЦБ");
Сообщить("Новое значение = "+Константы["ПрефиксНумерации"].Получить());
/ЛТример: Очистить значения всех констант
Для Каждого ОчереднаяКонстанта Из Константы Цикл
ОчереднаяКонстанта. Установить(Неопределено); КоненЦикла;

// СоздатьНабор()
//Пример: Установить новые значения нескольких констант
Набор = Константы. СоздатьНабор("Руководитель, Бухгалтер"); Набор. Руководитель = "НиколаевДенис Павлович"; Набор. Бухгалтер = ""; Набор. Записать();

566
567
Краткий справочник разработчика
Константы


Последовательность событий при записи констант из формы

Особенности внутренней реализации объекта КонстантыНабор таковы, что при записи набора констант, обработчики события ПередЗаписью() и ПриЗаписи() модуля менеджера значения константы будут вызваны для каждой константы, входящей в записываемый набор.
Замечание. Работа с формой констант осуществляется при помоши объекта КонстантыНабор, который, в свою очередь, использует объектКонстантаМенеджерЗначения.<имя>.
568
569
Справочники
![]() |
![]() |
![]() |
![]() |
|
Справочники
Объекты встроенного языка для работы со справочниками
Использование объектов:
II Справочники
//Пример: Вывести все типы ссылок на элементы справочников, существующие
//в конфигурации
Массив = Справочники. ТипВсеСсылки().Типы();
Для Каждого ОчереднойТип из Массив Цикл
Сообщить(ОчереднойТип); КонецЦикла;

// .<имя справочника> // [<ими справочника>] // Дли Каиедого... Из... Цикл... КонецЦикла;
//Пример: Создать новую группу справочника Номенклатура
НоваяГруппа = Справочники. Номенклатура. СоздатьГруппу(); НоваяГруппа. Наименование = "Моя новая группа"; НоваяГруппа. Записать();
//Пример: Открыть форму выбора справочника Номенклатура
Форма = Справочники["Номенклатура"].ПолучитьФормуВыбора(); Форма. Открыть();
*Заливкой выделен объект манипулирования данными
<*" Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.
570
571
Краткий справочник разработчика
Справочники
![]()








// НайтиПоКоду()
// НайтиПоНаименованик>()
// НайтиПоРеквизитуО
// ПустаяСсылка()
// ПолучнтьСсылку()
// .<имя предопределенного элемента справочника>
//Пример: Проверить, помечен лн на удаление элемент справочника Номенклатура //c кодом 13
Если Справочники. Номенклатура. НайтиПоКоду(13).ПометкаУдаления тогда
Сообщить("Элемент с кодом 13 помечен на удаление"); КонецЕсли;
/ЛТример: Является ли элемент справочника Номенклатура с наименованием
//«Услуги» группой
Если Справочники. Номенклатура
.НайтиПоНаименованию"Услуги", Истина).ЭтоГруппа тогда Сообщить("Элемент Услуги является группой"); КонецЕсли;
//Пример: Проверить, что для всех элементов задан вид номенклатуры
ПустаяСсылкаПеречисления = Перечисления. ВидыНоменклатуры. ПустаяСсылка(); Если Не Справочники. Номенклатура. НайтиПоРеквизит("'ВидНоменклатуры",
ПустаяСсылкаПеречисления).Пустая() тогда
Сообщить("Есть элементы для которых не задан вид номенклатуры"); КонецЕсли;
//Пример: Передать пустую ссылку в параметр метода
Выборка = Справочники. Номенклатура
.Выбрать(Справочники. Номенклатура. ПустаяСсылка());_____________
// Выбрать()
// ВыбратьИерархически()
//Пример: Вывести список элементов, расположенных в корне справочника
Выборка = Справочники. Номенклатура
.Выбрать(Справочники. Номенклатура. ПустаяСсылкаО); Пока Выборка. Следующий() Цикл Если Не Выборка. ЭтоГрутша тогда
Сообщить(Выборка); КонецЕсли; КонецЦикла;
//Пример: Удалить все элементы иерархического справочника
Выборка = Справочники. Номенклатура. ВыбратьИерархически(); Пока Выборка. Следующий() Цикл
Выборка. Удалить(); КонецЦикла;
![]()
// СоздатьГруппу() // СоздатьЭлемент()
//Пример: Создать новый элемент справочника Сотрудники
НовыйЭлемент = Справочники. Сотрудники. СоздатьЭлемент(); НовыйЭлемент. Наименование = ""; //Заполнить табличную часть
НоваяСтрокаТабличнойЧасти = НовыйЭлемент. ТрудоваяДеятельность. Добавить(); НоваяСтрокаТабличнойЧасти. Организация = "OOO НТЦ"; НоваяСтрокаТабличнойЧасти. НачалоРаботы = Дата(2003,05,01); НоваяСтрокаТабличнойЧасти. ОкончаниеРаботы = Дата(2003,12,31); НоваяСтрокаТабличнойЧасти. Должность = "Программист"; НовыйЭлемент. Записать();


572
573
Краткий справочник разработчика
Справочники
![]() | |
![]() | ![]() |
// Владелец // Родитель // Ссылка
// Пример: запретить изменение подчиненных элементов, если у владельца // установлено соответствующее свойство «ИзмененияЗапрещены» // в модуле формы элемента справочника
Процедура ПередЗаписью(Отказ)
Если Владелец. ИзмененияЗапрещены Тогда Отказ = Истина;
КонецЕсли; КонецПроцедуры
// Ссылка
//Пример: Заполнить табличную часть документа ПриходнаяНакладная всеми //элементами из указанной группы справочника Номенклатура
Выборка = Справочники. Номенклатура. ВыбратьИерархическиСПолеВвода!); Пока Выборка. Следующий() Цикл
СсылкаНаНоменклатуру = Выборка. Ссылка; Если СсылкаНаНоменклатуру. ЭтоГруппа тогда
Продолжить; КонецЕсли;
НоваяСтрока = Материалы. Добавить(); НоваяСтрока. Материал = СсылкаНаНоменклатуру; КонецЦикла;
![]()



// ПолучитьОбъект() // Скопировать()
// ПолучитьОбъект()

// Пример: Изменить наименование элемента справочника
Элемент = Справочники. Номенклатура. НайтиПоКоду(10).ПолучитьОбъект(); Элемент. Наименование = "Мое новое наименование"; Элемент. Записать();
// Пример: Заполнить справочник тестовыми данными
Элемент = Справочвики. Номенклатура. СоздатьЭлемент(); Элемент. Наименование = "Тестовый элемент"; Элемент. ЗаписатьО; Для ш = 1 по 1000 Цикл
НовыйЭлемент = Элемент. СкопнроватьО;
НовыйЭлемент. Записать(); КонецЦикла;
//Пример: пометить все элементы неиерархического справочника на удаление
Выборка = Справочники. Клиенты. Выбрать(); Пока Выборка. Следующий() Цикл
Выборка. ПолучитьОбъект().УстановитьПометкуУдаления(Истина); КонецЦикла;

574
575
Краткий справочник разработчика
|
Последовательность событий при записи элемента справочника из формы элемента
Запись элемента справочника |
Модуль объекта |
Модуль
формы
элемента
справочника
Документы
Объекты встроенного языка для работы с документами:
*Заливкой выделен объект манипулирования данными
*" Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.

576
577
Краткий справочник разработчика
Документы








Использование объектов:
// Документы
//Пример: вывести все типы ссылок на элементы справочников, существующие в конфигурации
Массив = Документы. ТипВсеСсылки()Типы(); Для Каждого ОчереднойТип из Массив Цикл
Сообщить(ОчереднойТип);
КонецЦикла;
// НайтиПоНомеру() // НайтиПоРеквизиту() // ПустаяСсылка()
//Пример: Проверить, проведен ли документ ПриходнаяНакладная с номером 3
Если Документы. ПриходнаяНакладная. НайтиПоНомеру(3).Проведен тогда
Сообщить("Документ с номером 3 проведен"); КонецЕсли;
//Пример: Проверить, что во всех документах ПриходнаяНакладная заполнен
//реквизит Склад
ПустаяСсьшкаСклада = Справочники. Склады. ПустаяСсылка();
Если Не Документы. ПриходнаяНакладная
.НайтиПоРеквизиту("Склад", ПустаяСсылкаСклада).Пустая() тогда Сообщит("'Есть документы, у которых не заполнен реквизит Склад"); КонецЕсли;
![]()

II .<имя документа> // [<имя документа>] // Для Каждого... Из... Цикл... КонецЦикла;
/Шример: Открыть форму нового документа ОказаниеУслуги для интерактивного //заполнения
Форма = Документы["ОказаниеУслуги"].ПолучитьФормуНовогоДокумента(); Форма. Открьпь();
//Пример: Открыть формы списка всех документов, существующих в
конфигурации
Для Каждого ОчереднойДокумент Из Документы Цикл
Форма = ОчереднойДокумент. ПолучитьФормуСписка();
Форма. Открыть(); КонецЦикла;
// Выбрать()
//Пример: Выбрать все документы ПриходнаяНакладная за текущий месяц
Выборка = Документы. ПриходнаяНакладная
.Выбрать(НачалоМесяца(ТекущаяДата()),КонецМесяца(ТекущаяДата())); Пока Выборка. Следующий() Цикл
Сообщить(Выборка); КонецЦикла;

// СоздатьДокумент()
//Пример: Создать новый документ ПриходнаяНакладная
НовыйДокумент = Документы. ПриходнаяНакладная. СоздатьДокументО;
НовыйДокумент. Дата = ТекущаяДата();
НовыйДокумент. Склад = Справочники. Склады. Основной;
//Заполнить табличную часть
НоваяСтрокаТабличнойЧасти = НовыйДокумент. Материалы. Добавить();
НоваяСтрокаТабличнойЧасти. Материал ■ Справочники. Номенклатура. НайтиПоКоду(6);
НоваяСтрокаТабличнойЧасти. Количество = 10;
НоваяСтрокаТабличнойЧасти. Цена = 22,5;
НоваяСтрокаТабличнойЧасти. Сумма = 225;
НовыйДокумент. Записать();
578
579
Краткий справочник разработчика
Дою
менты

// ПолучитьОбъект()




// Ссылка
//Пример: В модуле объекта вызвать процедуру проверки заполнения реквизитов документа
Если Не ПроверитьЗаполнениеРеквизитов(ЭтотОбъект. Ссылка) тогда
Сообщить(«Реквизиты документа не заполнены!»); КонецЕсли;
//Пример: Удалить все документы ПриходнаяНакладная
Выборка = Документы. ПриходнаяНакладная. Выбрать(); Пока Выборка. Следующий() Цикл
Выборка. ПолучитьОбъект()Удалить(); КонецЦикла;
Последовательность событий при записи документа из формы документа
![]() |
![]() |
![]() |
|
II ПолучитьОбъект() // Скопировать()
//Пример: Пометить документ на удаление
НенужныйДокумент = Документы. ОказаниеУслуги
.НайтиПоНомеру(13).ПолучитьОбъект(); НенужныйДокумент. УстановитьПометкуУдаления(Истина);

// Ссылка
//Сформировать список ссылок на все документы ПриходнаяНакладная за //текущий месяц
СписокНакладных = Новый СписокЗначений; Выборка = Документы. ПриходнаяНакладная
.Выбрать(НачалоМесяца(ТекущаяДата()),КонецМесяца(ТекущаяДата())); Пока Вьтборка. Следующий() Цикл
СписокНакладных. Добавит^Выборка. Ссылка);
КонецЦикла; ^^
580
581
Краткий справочник разработчика
Документы
Последовательность событий при проведении документа из формы документа
Последовательность событий при отмене проведени документа из формы документа
|
|

582
583
Краткий справочник разработчика
Перечислени


Перечисления
Объекты встроенного языка для работы с перечислениями:
// .<имя перечисления>
// [<имя перечисления >]
// Для Каждого... Из... Цикл... КонецЦикла;
//Пример: Открыть форму выбора перечисления
Форма = Перечисления. ВидыНоменклатуры. ПолучитьФормуВыбора(); Форма. Открыть();
![]() | |
![]() | |
|
ПеречислениеСписок.<имя>
// .<имя значения перечисления>
// [<имя значения перечисления >]
// [<идекс элемента коллекции>]
// Для Каждого... Из... Цикл... КонецЦикла;
// ПустаяСсылка()
//Пример: Получить пустую ссылку на значение перечисления
ПустаяСсылкаПеречисления= Перечисления. ВидыНоменклатуры. ПустаяСсылка(); Если ТекущаяНоменклатура. ВидНоменклатуры = ПустаяСсылкаПеречисления тогда //предложить заполнение вида номенклатуры
...
КонецЕсли;
Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.
Использование объектов:
// Перечисления
//Пример: Открыть форму списка перечисления
Форма = Перечисления. ВидыНоменклатуры. ПолучитьФормуСписка(); Форма. Открыть();


584
585
Планы видов характеристик
Планы видов характеристик
Объекты встроенного языка для работы с планами видов характеристик
Свойства и методы взаимодействия перечисленных объектов в большинстве своем аналогичны свойствам и методам объектов, предназначенных для работы со справочниками (см. раздел «Объекты встроенного языка для работы со справочниками» на странице 570).
Последовательность событий при записи вида характеристики из формы
|
|
*Заливкой выделен объект манипулирования данными
■ Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.

586
587
Планы счетов
|
ПланыСчетовМенеджер | | ПланСчетовСписок.<имя> |
Планы счетов
Глобальный контекст |
ПланСчетовМенеджер.<имя> |
И ПланСчетовОбъект. ошя> |
ПланСчетовСсылка.<имя> |
ПланСчетовВыборка.<имя> |
ПланСчетовВидыСубконто.<имя> |
ПланСчетовВидыСубконтоСтрока.^ашя> |
Объекты встроенного языка для работы с планами счетов
*Заливкой выделен объект манипулирования данными
ПланСчетовВидыСубконто^имя>. Используется для доступа к методам специальной табличной части счета ВидыСубконто в целом.
ПланСчетовВидыСубконтоСтрока^имя>. Строка специальной табличной части счета ВидыСубконто.
Свойства и методы взаимодействия перечисленных объектов в большинстве своем аналогичны свойствам и методам объектов, предназначенных для работы со справочниками (см. раздел «Объекты встроенного языка для работы со справочниками» на странице 570).
Последовательность событий при записи счета из формы

<*" Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.
589
Планы видов расчета
|
Планы видов расчета
ВытесняющиеВидыРасчетаСтрока.<имя> |
Объекты встроенного языка для работы с планом видов расчета
<*^ Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.
ВытесняющиеВидыРасчета.<имя>. Предопределенная
табличная часть вида расчета - список вытесняющих видов расчета. Такая табличная часть определена только для планов видов расчета с признаком ИспользуетПериодДействия. Имеет единственную колонку - ВидРасчета типа ПланВидовРасчетаСсылка.<имя>.
ВытесняющиеВидыРасчетаСтрока^имя>. Строка
предопределенной таблицы вытесняющих видов расчета.
ВедущиеВидыРасчета.<имя>. Предопределенная табличная
часть вида расчета - список ведущих видов расчета. Имеет
единственную колонку - ВидРасчета типа
ПланВидовРасчетаСсылка.<имя>.
ВедущиеВидыРасчетаСтрока.<имя>. Строка предопределенной таблицы ведущих видов расчета.
БазовыеВидыРасчета.<имя>. Предопределенная табличная часть вида расчета - список ведущих видов расчета. Такая табличная часть (свойство БазовыеВидыРасчета) определена только для планов видов расчета со свойством ЗависимостьОтБазы не равным значению «Не зависит». Имеет единственную колонку - ВидРасчета типа ПланВидовРасчетаСсылка^имя>.
БазовыеВидыРасчетаСтрока.<имя>. Строка предопределенной таблицы базовых видов расчета.
Свойства и методы взаимодействия перечисленных объектов в большинстве своем аналогичны свойствам и методам объектов, предназначенных для работы со справочниками (см. раздел «Объекты встроенного языка для работы со справочниками» на странице 570).
*Заливкой выделен объект манипулирования данными

590
591
|
Последовательность событий при записи вида расчета из формы
Регистры сведений
Объекты встроенного языка для работы с регистрами сведений

*Заливкой выделен объект манипулирования данными
<*" Узнай больше!
Про основные виды объектов встроенного языка можно прочитать в главе «Виды объектов встроенного языка, предназначенные для работы с данными прикладных объектов конфигурации» на странице 551.
РегистрСведенийМенеджерЗаписи^имя>. Позволяет читать, записывать и удалять отдельную запись регистра сведений. Используется только для регистров сведений, не изменяемых
592
593
Краткий справочник разработчика
Регистры сведе
ни








регистраторами, т. е. для которых в конфигураторе установлен режим записи «Независимый».
РегистрСведенийЗапись.<имя>. Предоставляет доступ к записи регистра сведений. Объект не создается непосредственно, а предоставляется другими объектами, связанными с регистром сведений. Например, данный объект представляет записи регистра в наборе записей.
РегистрСведенийКлючЗаписи.<имя>. Представляет собой набор значений, однозначно идентифицирующих запись регистра. Объект используется в тех случаях, когда необходимо сослаться на определенную запись. Например, он выступает в качестве значения свойства «ТекущаяСтрока» табличного поля, отображающего список записей регистра.
Использование объектов:
// РегистрыСведений
//Прнмер: Получить текущую цену из периодического регистра сведений Цены
Элемент = Справочники. Номенклатура. НайтиПоКоду(4); Отбор = Новый Структурв("Номенклатура",Элемент); ЗначенияРесуроов = РегистрыСведений. Цены
.ПолучитьПоследнее(ТекущаяДата(), Отбор);
// СоздатьКлючЗаписи()
//Пример: Активизировать требуемую строку списка регистра сведений
СтруктураКлючевыхПолей = Новый Структура;
СтруктураКлючевыхПолей. Вставить("Период",Дата(""));
СтруктураКлючевыхПолей. Вставить("Номенклатура",
|
Из за большого объема этот материал размещен на нескольких страницах:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
























