- •Основы программирование в среде «1с: предприятие»
- •1. Предметно-ориентированное моделирование информационных систем
- •1.1. Понятие предметно-ориентированного моделирования
- •1.2. Типы моделей
- •2. Система программ «1с: Предприятие 8»
- •2.1. Состав системы программ «1с: Предприятие 8»
- •2.2. Структура конфигурации
- •2.3. Архитектуры системы программ «1с: Предприятие»
- •2.4. Платформенно-зависимая модель «1с: Предприятие»
- •3. Объектная модель платформы «1с: Предприятие»
- •3.1. Объекты для построения платформенно-зависимой модели
- •3.2. Общая структура основного объекта
- •4. Основы работы с информационной базой
- •4.1. Создание информационной базы
- •4.2. Перенос информационной базы
- •4.3. Объекты системы
- •4.4. Классификация объектов
- •4.5. Прикладные объекты
- •4.6. Подчиненные объекты
- •4.7. Встроенный язык системы
- •4.8. Виды модулей
- •4.9. Подсистемы
- •4.10. Отладка конфигурации
- •Лабораторная работа 1
- •5. Справочники
- •5.1. Назначение справочников
- •5.2. Программные объекты справочников
- •5.3. Подчиненные справочники
- •5.4. Иерархические справочники
- •5.5. Модуль объекта Справочник
- •5.6. Свойства справочников
- •5.7. Формы объектов
- •5.8. Представления объектов
- •5.9. Настройка интерфейса
- •5.10 Структура экрана в пользовательском режиме
- •Лабораторная работа 2
- •6. Документы
- •6.1. Назначение документов
- •6.2. Программные объекты документов
- •6.3. Проведение документа
- •6.4. Ввод на основании
- •6.5. Типы данных. Типообразующие объекты конфигурации
- •6.6. Заполнение реквизитов
- •6.7. Расчет суммы в строках документа
- •Лабораторная работа 3
- •7. Регистры
- •7.1. Назначение и свойства
- •7.2. Виды регистров
- •7.3. Виртуальные таблицы
- •7.4. Программные объекты регистров
- •7.5. Регистры накопления
- •7.6. Движения документа
- •7.7. Командный интерфейс регистров
- •Лабораторная работа 4
- •8. Отчеты
- •Лабораторная работа 5
- •9. Макеты и формы
- •9.1. Создание макета печатной формы
- •9.2. Редактирование макета
- •9.3. Редактирование формы
- •Лабораторная работа 6
- •10. Регистры сведений
- •10.1. Создание периодического регистра сведений
- •10.2. Использование периодического регистра сведений в документе
- •Лабораторная работа 7
- •11. Перечисления
- •Лабораторная работа 8
- •12. Оборотные регистры накопления
- •Лабораторная работа 9
- •13. Табличная модель платформы «1с: Предприятие»
- •13.1. Табличная модель данных
- •13.2. Виды таблиц базы данных
- •13.3. Создание запроса и использование его результатов
- •13.4. Структура и описание запроса
- •13.5. Взаимосвязь таблиц
- •13.6. Упорядочивание
- •13.7. Группировка и итоги
- •13.8. Параметры
- •14. Система компоновки данных
- •Лабораторная работа 10.1
- •Лабораторная работа 10.2
- •Лабораторная работа 10.3
- •Лабораторная работа 10.4
5.4. Иерархические справочники
Справочники могут обладать иерархической структурой. Механизм иерархии подобен механизму подчиненных справочников, за исключением того, что он реализован в рамках одной таблицы – таблицы справочника (рис.5.3).
Рис.5.3 Механизм иерархии справочника
Согласно табличной модели данных, каждая таблица справочника имеет поле Родитель (тип данных СправочникСсылка). В этом поле содержится ссылка на запись родительского элемента справочника. Если запись родительского элемента в поле ЭтоГруппа имеет значение Истина, то родительский элемент иерархии справочника является группой, иначе – элементом. Отсюда появляются два вида иерархии – групп и элементов и просто элементов. Так как в этом случае связь устанавливается внутри таблицы, здесь не используется механизм внешних ключей.
5.5. Модуль объекта Справочник
Модуль объекта отличается от модуля формы элемента справочника. Экранные формы отделены от самих объектов конфигурации. Именно в модуле объекта располагаются обработчики событий, связанных с элементом справочника.
Существуют следующие события, обработчики которых располагаются в модуле справочника:
ПриКопировании
Событие возникает при создании элемента справочника копированием. В обработчике события ПриКопировании можно вмешаться в этот процесс и более интеллектуально заполнить некоторые реквизиты элемента справочника.
ПередЗаписью
Процедура-обработчик вызывается после начала транзакции, но до начала записи элемента справочника. В данном обработчике можно отказаться от записи элемента.
ПриЗаписи
Событие возникает после записи элемента справочника в базу данных, но до окончания транзакции записи. В данном обработчике также можно отказаться от записи элемента.
ПередУдалением
Событие возникает перед непосредственным удалением элемента или группы справочника из базы данных. В обработчике события это действие можно отменить.
ПриУстановкеНовогоКода
Событие возникает в момент, когда выполняется установка нового кода элемента справочника.
ОбработкаЗаполнения
Событие возникает при вводе элемента справочника на основании, а также при выполнении метода Заполнить. В процедуре-обработчике этого события должен быть описан алгоритм заполнения реквизитов элемента справочника на основании переданного значения.
Обработчики этих событий должны располагаться в модуле объекта и только там, независимо от наличия у справочника различных форм. Обработчики событий будут вызываться всегда при наступлении указанных событий, даже если событие инициировано программными вызовами, например методами Записать и Удалить.
Приведем пример использования обработчика события. Допустим, в конфигурации категорически не допускается ввод позиции номенклатуры без указания группы.
5.6. Свойства справочников
Название и структура конкретного справочника определяется при его создании в конфигураторе. Каждый элемент справочника описывается стандартными реквизитами (рис. 5.4)
Рис. 5.4
и пользовательскими реквизитами на закладке Данные окна редактирования объекта Справочник. Если справочник иерархический, то у него будет доступен стандартный реквизит Родитель. Если справочник подчинен другому объекту конфигурации, то у него будет доступен реквизит Владелец.
Каждый элемент справочника может содержать некоторый набор информации, которая одинакова по структуре, но различна по количеству, и предназначена для разных элементов справочника. Для хранения такой информации используют табличные части со своими подчиненными реквизитами (рис.5.5)
Рис. 5.5
Для удобства использования элементы справочника могут быть сгруппированы пользователем по какому-нибудь принципу. Возможность создания таких групп задается свойством Иерархический справочник на закладке Иерархия (рис. 5.6).
Рис. 5.6
В этом случае элемент справочника, представляющий собой группу, будет являться родителем для всех элементов и групп, входящих в эту группу. Такой вид иерархии называется иерархией групп и элементов (см. рис. 5.6). Возможен и другой вид иерархии – иерархия элементов. В этом случае в качестве родителя может выступать сам элемент справочника.
Иногда бывает необходимо, чтобы в справочнике некоторые элементы существовали всегда, независимо, от действий пользователя, т. е. пользователю запрещено их удалять. Такие элементы называются предопределенными. Они задаются на закладке Прочие по кнопке Предопределенные (рис.5.7). К таким элементам можно обращаться из встроенного языка.
Рис.5.7