Динамические списки в формах строятся на основе системы компоновки данных. Для динамического списка или указывают отображаемый объект конфигурации (таблицу), или задают произвольный текст запроса, который будет использован для считывания данных.
Для каждого из двух "видов" динамических списков отборы устанавливаются по-разному:
1. Для обычного динамического списка: добавить условие с параметром отбора;
Пример: в списке товаров показывать только позиции с остатком больше 10
ТекстУсловия = " ГдеТоварыНаСкладеОстаток.КоличествоОстаток > 10";
Список.ТекстЗапроса= Список.ТекстЗапроса + ТекстУсловия;
2. Для динамичского списка с произвольным запросом: используется свойство Отбор.
Для простых условий используется тип данных ЭлементОтбораКомпоновкиДанных:
ЭлементОтбора.ЛевоеЗначение = Новый ПолеКомпоновкиДанных("Поле1");
ЭлементОтбора.ВидСравнения = ВидСравненияКомпоновкиДанных.Равно;
ЭлементОтбора.Использование = Истина;
ЭлементОтбора.ПравоеЗначение = Значение1;
Для сложных условий используется тип данных ГруппаЭлементовОтбораКомпоновкиДанных:
ГруппаОтбора = Список.Отбор.Элементы.Добавить(Тип("ГруппаЭлементовОтбораКомпоновкиДанных"));
ГруппаОтбора.ТипГруппы = ТипГруппыЭлементовОтбораКомпоновкиДанных.ГруппаИЛИ;
ЭлементОтбора = Список.Отбор.Элементы.Добавить(Тип("ЭлементОтбораКомпоновкиДанных"));
ЭлементОтбора.Родитель = ГруппаОтбора;
ЭлементОтбора.ЛевоеЗначение = Новый ПолеКомпоновкиДанных("Поле1");
ЭлементОтбора.ВидСравнения = ВидСравненияКомпоновкиДанных.Меньше;
ЭлементОтбора.Использование = Истина;
ЭлементОтбора.ПравоеЗначение = Значение1;
ЭлементОтбора = Список.Отбор.Элементы.Добавить(Тип("ЭлементОтбораКомпоновкиДанных"));
ЭлементОтбора.Родитель = ГруппаОтбора;
ЭлементОтбора.ЛевоеЗначение = Новый ПолеКомпоновкиДанных("Поле2");
ЭлементОтбора.ВидСравнения = ВидСравненияКомпоновкиДанных.Больше;
ЭлементОтбора.Использование = Истина;
ЭлементОтбора.ПравоеЗначение = Значение2;
Выше была теория. В прилагаемом архиве: простая конфигурация и два расширения, демострирующие, на примере использования механизма расширений, применение произвольных отборов в динамических списках без изменения конфигурации.
Одно расширение (Расширение1.cfe) демонстрирует отбор для обычного динамического списка (форма списка номенклатуры - фильтр по остаткам), второе (Расширение2.cfe) - отбор для динамического списка с произвольным запросом (форма списка документов Поступление товаров - фильтр по контрагенту).
В архив входят: дамп демо-базы 1С (закрытой от изменений) и два расширения.