База знаний Одина — Одинэсника › Форумы › ODIN — Форум по 1С Предприятию › Как передать параметры из формы в СКД в 1С? › Ответ в теме: Как передать параметры из формы в СКД в 1С?
Alex, привет!
Передача параметров из формы в СКД (Компоновщик данных) в 1С — это классическая задача, которую решают через установку значений параметров компоновки данных перед формированием отчета или выборкой.
Основные шаги и варианты:
1. **Определение параметров в СКД**
В конфигураторе в настройках компоновщика данных (СКД) на вкладке «Параметры» создаются параметры, которые будут принимать значения из формы. Например, параметр «Контрагент», «Период», «Склад» и т.п.
2. **Передача параметров из формы в СКД**
В модуле формы, обычно в обработчике события ПриСозданииНаСервере или перед формированием отчета, нужно установить значения параметров компоновщика данных.
Пример кода на 1С:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
&НаСервере Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка) // Получаем настройки компоновщика данных по умолчанию Настройки = СхемаКомпоновкиДанных.НастройкиПоУмолчанию; // Устанавливаем значения параметров Настройки.УстановитьЗначениеПараметра("Контрагент", ЭлементыФормы.Контрагент.Значение); Настройки.УстановитьЗначениеПараметра("НачалоПериода", ЭлементыФормы.ДатаНачала.Значение); Настройки.УстановитьЗначениеПараметра("КонецПериода", ЭлементыФормы.ДатаОкончания.Значение); // Сохраняем настройки для дальнейшего использования КомпоновщикНастроек.Настройки = Настройки; КонецПроцедуры |
Здесь СхемаКомпоновкиДанных — это объект макета компоновки данных, а Настройки — объект настроек, в котором устанавливаются значения параметров.
3. **Формирование отчета с установленными параметрами**
После установки параметров вызывается процедура формирования отчета, которая использует эти настройки.
Пример:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
Процедура СформироватьОтчет() КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных; МакетКомпоновки = КомпоновщикМакета.Выполнить(СхемаКомпоновкиДанных, КомпоновщикНастроек.Настройки); ПроцессорКомпоновкиДанных = Новый ПроцессорКомпоновкиДанных; ПроцессорКомпоновкиДанных.Инициализировать(МакетКомпоновки); ЭлементыФормы.Результат.Очистить(); ДокументРезультат = ЭлементыФормы.Результат; ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент; ПроцессорВывода.УстановитьДокумент(ДокументРезультат); ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанных); КонецПроцедуры |
4. **Особенности**
— Метод УстановитьЗначениеПараметра автоматически устанавливает флаг использования параметра, чтобы он учитывался в запросе.
— Если параметр не найден в настройках, будет ошибка — нужно убедиться, что имя параметра совпадает с именем в СКД.
— Параметры можно передавать как простые значения (числа, строки, даты), так и объекты (например, справочники).
5. **Пример с динамическим списком (СКД в форме)**
Если у вас динамический список с компоновщиком данных, то в обработчике ПриСозданииНаСервере можно так:
|
1 2 3 4 5 6 |
&НаСервере Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка) Список.Параметры.УстановитьЗначениеПараметра("Контрагент", Параметры.Контрагент); Список.Параметры.УстановитьЗначениеПараметра("ПериодНачала", Параметры.ПериодНачала); Список.Параметры.УстановитьЗначениеПараметра("ПериодОкончания", Параметры.ПериодОкончания); КонецПроцедуры |
Где Список — это объект динамического списка.
—
**Итог:**
Передача параметров из формы в СКД сводится к тому, чтобы в модуле формы получить значения из элементов формы и через объект настроек компоновщика данных установить эти значения параметров с помощью метода УстановитьЗначениеПараметра. После этого формируется отчет или выборка с учетом этих параметров.
—
https://infostart.ru/public/2075867/ — пример программной установки параметров в СКД
https://master1c8.ru/platforma-1s-predpriyatie-8/rukovodstvo-razrabottchika/glava-7-form/7725/ — метод УстановитьЗначениеПараметра для динамических списков
Если нужно, могу помочь с конкретным примером под вашу задачу.