Download the PHP package arrilot/bitrix-iblock-helper without Composer
On this page you can find all versions of the php package arrilot/bitrix-iblock-helper. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package bitrix-iblock-helper
Данный пакет больше активно не поддерживается
Причина - мы больше не используем Битрикс в своих проектах. Если вам интересен этот проект и вы хотите заняться его поддержкой - форкните его и создайте Issue в данном репозитории чтобы мы поместили здесь ссылку на форк.
Хэлперы для упрощения работы с инфоблоками/хайлоадблоками
Данный пакет представляет собой пару классов которые позволяют удобно и производительно получать
- Идентификаторы инфоблоков по их символьным кодам
- Различную информацию о хайлоадблоках по названию таблицы
Производительность достигается за счёт того, что мы не запрашиваем из БД данные каждый раз когда вызывается какой-либо из методов Вместо этого данные получаются из БД один раз и сразу по всем инфоблокам/хайлоадблокам и опционально могут еще и кэшироваться
Установка
Использование
Инфоблоки
Рекомендуемый способ использования - добавить в проект следующую функцию-хэлпер:
Допустим, есть инфоблок типа other
и с символьным кодом articles
.
Его ID можно получить при помощи одного из вариантов:
$id = iblock_id('articles', 'other')
- строгий вариант$id = iblock_id('other:articles')
- тоже самое$id = iblock_id('articles')
- более удобный в случае когда коды инфоблоков можно считать уникальными.
Независимо от количества вызовов iblock_id()
запрос в базу будет выполнен только один раз за и получит данные по всем инфоблокам.
Хайлоадблоки
Рекомендуемый способ использования - добавить в проект следующие функции-хэлперы:
Кэширование
Для увеличения быстродействия пакет использует два уровня кэша для массива идентификаторов Необходимо понимать как эти уровни работают, чтобы избежать некоторых подводных камней.
Первый уровень (локальный кэш) - кэширование массива данных в статическую переменную класса. По-умолчанию - включён. Это кэширование работает только в рамках одного HTTP запроса, но очень полезно потому что позваляет избежать множества запросов в БД.
Второй уровень (внешний кэш) - кэширование еще и во внешнем кэше через стандартный механизм кэширования Битрикса на N минут. По-умолчанию - выключен. Он может быть полезен, например, если на проекте есть очень много инфоблоков.
Для включения необходимо добавить в init.php
(или куда-то туда):
Сброс кэша
Пакет предоставляет несколько методов для сброса кэша. Зачастую их использование не требуется, но бывают кейсы когда без них никуда.