СоздатьМенеджерЗначения()

//Пример: Вывести значения всех констант, существующих в конфигурации

Для Каждого ОчереднаяКонстанта Из Константы Цикл

ИмяКонст=ОчереднаяКонстанта. СоздатьМенеджерЗначения().Метаданные().Имя-ЗначениеКонст = ОчереднаяКонстанта. Получить(); Сообшить("Константа "+ИмяКонст+" = "+ЗначениеКонст); КонецЦикла;

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