1С-Битрикс. Ядро d7 в работе с элементами инфоблоков
Код, который будет написан ниже я проверял. Считаю себя middle, но почти не получаю критики. Это моя первая статья на Хабре. Для этого я здесь, жду обратную связь.
Начинающему программисту на 1С-Битрикс очень хорошо известна функция для получения элементов инфоблока.
'DESC'], // правила сортировка
[
'>=DATE_ACTIVE_FROM' => '29.11.2023',
'IBLOCK_ID' => $iblockId
], // фильтр
false, // правила группировки
false, // параметры постраничной навигации
['PROPERTY_*', '*'], // выборка
);
В блоке выше описана сигнатура метода для работы с элементами инфоблоков в Битриксе. У неё, на первый взгляд, есть свои преимущества, она задокументирована, о ней много статей на форумах. Её дебагинг уже разобран подробно за время существования CMS. Замечу, что существует ряд задач, для решения которых она не годится. Эта функция в нынешних реалиях разработки встретится даже начинающему программисту довольно быстро.
К счастью, разработчики 1С-Битрикс упорно продолжают распиливать монолитные конструкции, которые начинале писать ещё на рубеже тысячелетий. Сейчас в арсенале у программиста есть, по крайней мере, 2 разных способа работы с элементами инофблоков в d7 ядре. Рассмотрим первый (он плохой, ниже я рассказываю, почему, можно переходить сразу ко второму).
Наследники DataManager в 1С-Битрикс
[
'>=ACTIVE_FROM' => '29.11.2023',
'IBLOCK_ID' => $iblockId,
],
'select' => [
'ID',
'NAME',
],
]);
Обращу внимание на то, что у класса ElementTable и метода getList есть документация. К сожалению, получить свойства информационного блока так не получится. Как известно, что в 1С-Битрикс долго не могли решить проблему раздельного хранения свойств и полей. Этот метод, в свою очередь, подойдёт скорее для беглой выборки идентификаторов и отработает быстрее, чем \CIBlockElement: getList. Для получения свойств данным методом придется поломать голову. С помощью ключа runtime можно докинуть магии, нашёл пример тут.
ORM в 1С-Битрикс
К сожалению, так не пойдёт, рассмотрим другой пример. Во-первых, перейдем в настройки интересующего нас инфоблока. Во-вторых, заполним поле «Символьный код API».
Настройки информационного блока «История состояний»
Далее будем использовать класс \Bitrix\Iblock\Elements\Element*****Table, где ***** — «Символьный код API».
[
'>=ACTIVE_FROM' => '29.11.2023'
],
'select' => [
'ID',
'NAME',
'STATE', // свойство инфоблока История состояний в Битрикс24
'IBLOCK_SECTION',
],
])->fetchCollection();
foreach ($elementsCollection as $elementObject) {
#var_dump($elementObject) не сработает, можете проверить (это не массив)
$name = $elementObject->getName(); # или $elementObject['NAME']
$id = $elementObject->getId(); # или $elementObject['ID']
$state = $elementObject->getState()->getValue(); # у по другому
$iblockSectionId = $elementObject->getIblockSection()->getName();
}
Метод fetchCollection () позволяет получить свойства с правильно именованными ключами. В свою очередь советую попробуйте сами запустить этот блок кода, используя метод fetchAll (), всё будет не так радужно. Для получения мы можем использовать ключ ['STATE'] или же метод getState (). Для правильного использования методов используется CamelCase. Также поля можно получить методом →get ('ID'). $iblockSectionId→getIblockSection ()→getName () получает название раздела инфоблока.
К счастью, этим функционал d7 в модуле iblock 1С-Битрикс не ограничивается. Например, мы можем с легкостью, получить нужные нам разделы инфоблоков, работая с разделом, как с объектом. Рассмотрим пример.
[
'UF_HEAD' => 9,
],
'select' => ['ID', 'NAME'],
])->fetchAll();
$managerDepartmentNames = '';
foreach ($rsDepartments as $dep) {
$managerDepartmentNames .= $dep['NAME'] . ' ';
}
Заметьте, что код выше содержит сразу нескольо подключаемых классов. Об этом поговорим в следующем разделе статьи. В данном куске кода я получаю названия всех отделов, в которых руководителем является пользователь с 9 идентификатором. Замечу, что этот код относится к продукту Битрикс24 компании 1С-Битрикс. Итак, с помощью метода Section: compileEntityByIblock () мы получаем класс для работы с разделами инфоблока оргуструктуры. Напомню, что нечто подобное мы делали выше, когда создавали символьный код API для инфоблока и писали его класс в коде напрямую. В свою очередь, для работы с разделами используется такой метод. Обращу ваше внимание на то, что ключи у массива, передаваемого в getList, те же, что и у элементов, фильтровать по дополнительным полям легко, также как и получить их (добавить в массив ['ID', 'NAME', 'UF_HEAD']).
Полезные ссылки
О классе Option очень хорошо написано в официальной документации. О классе DataManager также читаем там.
Заключение
Я постараюсь писать больше статей о ядре d7. Вероятно я расскажу подробнее о кэшировании запросов (и о кэшировании в 1С-Битрикс в принципе).