Перейти к основному содержимому
Версия: 5.x

Операторы групп объектов

Операторы групп объектов - это набор операторов для создания свойств, работающих с текущим состоянием группы объектов на форме.

Синтаксис

FILTER groupObjectId
VIEW groupObjectId
ORDER groupObjectId

Описание

Операторы групп объектов создают свойства, которые принимают на вход такое же количество параметров, как и количество объектов в группе объектов. Эти операторы не могут использоваться внутри выражений.

Оператор FILTER создает свойство, значением которого будет являться TRUE, если переданный в качестве параметров набор объектов проходит все критерии фильтрации на форме, иначе значением свойства будет являться NULL.

Оператор VIEW создает свойство, значением которого будет являться TRUE, если переданный в качестве параметров набор объектов отображается в данный момент на форме, иначе значением свойства будет являться NULL.

Оператор ORDER создает свойство, значение которого определяет относительный порядок переданного в качестве параметра набора объектов на форме. Значение этого свойства обычно используется в блоках ORDER других свойств, например PARTITION, FOR, и т. д.

Параметры

Примеры

CLASS Store;
name = DATA STRING[100] (Store);

FORM stores
OBJECTS s = Store
;
countF 'Кол-во фильтр. складов' = GROUP SUM 1 IF [ VIEW stores.s](Store s);
orderF 'Порядок в группе объектов' (Store s) = PARTITION SUM 1 IF [ FILTER stores.s](s) ORDER [ ORDER stores.s](s), s;
setNameX 'Добавить X к имени'() {
LOCAL k = INTEGER ();
k() <- 0;
FOR [ FILTER stores.s](Store s) ORDER [ ORDER stores.s](s) DO {
k() <- k() + 1;
name(s) <- 'X' + k() + name(s);
}
}