Операторы групп объектов
Операторы групп объектов - это набор операторов для создания свойств, работающих с текущим состоянием группы объектов на форме.
Синтаксис
FILTER groupObjectId
VIEW groupObjectId
ORDER groupObjectId
Описание
Операторы групп объектов создают свойства, которые принимают на вход такое же количество параметров, как и количество объектов в группе объектов. Эти операторы не могут использоваться внутри выражений.
Оператор FILTER
создает свойство, значением которого будет являться TRUE
, если переданный в качестве параметров набор объектов проходит все критерии фильтрации на форме, иначе значением свойства будет являться NULL
.
Оператор VIEW
создает свойство, значением которого будет являться TRUE
, если переданный в качестве параметров набор объектов отображается в данный момент на форме, иначе значением свойства будет являться NULL
.
Оператор ORDER
создает свойство, значение которого определяет относительный порядок переданного в качестве параметра набора объектов на форме. Значение этого свойства обычно используется в блоках ORDER
других свойств, например PARTITION
, FOR
, и т. д.
Параметры
-
groupObjectId
Глобальный идентификатор группы объектов.
Примеры
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);
}
}