Программный отбор строк в таблице по условию в 1С 8.3

В данной статье рассмотрим способы установки отбора строк по условию для таблицы формы в управляемом приложении.

Такой подход часто применяется, когда у нас есть две таблицы, и нам нужно на лету “фильтровать” подчиненную таблицу в зависимости от того, какая строка основной таблицы выбрана. При этом в подчиненной таблице данные хранятся для всех строк, но отображаются только для нужной.

Разумеется, отбор строк программно для табличной части может понадобиться и в других случаях – например, при выполнении каких-то условий, в зависимости от каких-то реквизитов, и т.п.
Вот еще один пример – есть единая табличная часть “ДоходыИРасходы”, и для удобства пользователя она разнесена на две таблицы формы на разных закладках – доходы отдельно, расходы отдельно.

Свойство "ОтборСтрок" таблицы формы

В управляемом приложении для фильтрации видимых пользователю строк существует свойство таблицы формы “ОтборСтрок”. Оно задается при помощи фиксированной структуры. А чтобы сбросить его, нужно передать Неопределено.
Данное свойство является дополнительным для элемента управления ТаблицаФормы, связанного с табличной частью либо с таблицей значений. Для таблиц формы, которые связаные с наборами записей регистров, также можно указывать это свойство. У динамических списков все немного по-другому, о них будет написано ниже.

Итак, рассмотрим пример. пусть у нас будет Табличная часть Товары, в которой есть колонка Номенклатура (наличие остальных колонок не принципиально для данной задачи, мы их опустим для краткости), и “подчиненная” табличная часть “ВидыЗапасов”, в которой также есть колонка Номенклатура, и колонка ВидЗапасов.

Мы хотим реализовать следующую функциональность – при активизации строки табличной части Товары фильтровать виды запасов по нужной номенклатуре.

&НаКлиенте
Процедура ТоварыПриАктивизацииСтроки(Элемент)
	ТекущиеДанные = Элементы.Товары.ТекущиеДанные;
	Если ТекущиеДанные = Неопределено Тогда
		Возврат;
	КонецЕсли;
	Элементы.ВидыЗапасов.ОтборСтрок = Новый ФиксированнаяСтруктура("Номенклатура", ТекущиеДанные.Номенклатура);
КонецПроцедуры

Отбор для динамических списков

Динамические списки в своей основе построены на механизме СКД, а потому и отбор в них настраивается аналогично отбору в системе компоновки данных. Нам понадобится заполнить свойство Отбор, с типом ОтборКомпоновкиДанных.

ЭлементОтбораДанных = ТаблицаСписка.Отбор.Элементы.Добавить(Тип("ЭлементОтбораКомпоновкиДанных"));
ЭлементОтбораДанных.ЛевоеЗначение        = Новый ПолеКомпоновкиДанных("Номенклатура");
ЭлементОтбораДанных.Использование        = Истина;
ЭлементОтбораДанных.ВидСравнения        = ВидСравненияКомпоновкиДанных.Равно;            
ЭлементОтбораДанных.ПравоеЗначение        = СсылкаНаНоменклатуруОтбор;

Оставьте комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

10 − восемь =

К НАЧАЛУ