- Список разделов
- Описание crm.product.section.list
- Параметры
- Пример вызова
- Пользовательские комментарии
- Структура разделов
- Описание catalog.section.list
- Параметры
- Пример вызова
- Пользовательские комментарии
- Bitrix catalog.section как сделать вывод разделов и элементов?
- Битрикс: как узнать список разделов и элементов
- Как вывести список элементов инфоблока в 1С-Битрикс
- Как узнать значения свойств инфоблока в Битриксе
- Как вывести список разделов в 1С Битрикс
- автор: Dmitriy
Список разделов
Описание crm.product.section.list
Одностраничный компонент, необходим для управления списком разделов выбранного каталога. Компонент стандартный и входит в дистрибутив модуля.
В визуальном редакторе компонент расположен по пути CRM > Товары > Список разделов.
Параметры
Поле | Параметр | Описание |
Основные параметры | ||
---|---|---|
Количество разделов на странице по умолчанию | SECTION_COUNT | Максимальное число выводимых на одну страницу разделов. |
Торговый каталог | CATALOG_ID | Указывается каталог, разделы которого будут показаны на странице. |
Раздел | SECTION_ID | Указывается раздел, входящие разделы которого следует вывести. В случае, если оставить данный параметр неуказанным, то будут показаны разделы первого уровня. |
Имя переменной идентификатора раздела | SECTION_ID_PARAM | Указывается имя переменной, в которой будет содержаться идентификатор раздела. |
Шаблон пути к странице списка разделов | PATH_TO_SECTION_LIST | Указывается путь к странице с перечнем разделов выбранного каталога. |
Пример вызова
Пользовательские комментарии
Мы будем рады, если разработчики добавят свои комментарии по практическому использованию методов системы.
Для этого нужно всего лишь авторизоваться на сайте
Но помните, что Пользовательские комментарии, несмотря на модерацию, не являются официальной документацией. Ответственность за их использование несет сам пользователь.
Также Пользовательские комментарии не являются местом для обсуждения функционала. По подобным вопросам обращайтесь на форумы.
Источник
Структура разделов
Описание catalog.section.list
Компонент выводит список разделов инфоблока. Компонент стандартный, входит в дистрибутив модуля и содержит 4 шаблона: .default, old_version (шаблон .default до версии 14.0), tree и visual.
В визуальном редакторе компонент расположен по пути Контент > Каталог > Структура разделов.
Компонент относится к модулю Информационные блоки.
Параметры
Поле | Параметр | Описание | Примечание |
Основные параметры | |||
---|---|---|---|
Тип инфо-блока | IBLOCK_TYPE | Указывается один из созданных в системе типов информационных блоков. | |
Инфо-блок | IBLOCK_ID | Для выбранного типа инфоблоков указывается идентификатор необходимого информационного блока. | |
ID раздела | SECTION_ID | Указывается код, в котором передается идентификатор раздела. | |
Код раздела | SECTION_CODE | Указывается код раздела. | |
Источник данных | |||
Показывать количество элементов в разделе | COUNT_ELEMENTS | [Y|N] При отмеченной опции будет показано количество элементов в разделе. | |
Максимальная отображаемая глубина разделов | TOP_DEPTH | Параметр определяет максимальную глубину отображаемых разделов. | |
Поля разделов | SECTION_FIELDS | Указываются поля раздела, которые будут отображены на странице структуры разделов. Заполняется из публичной части редактора, удерживая клавишу Ctrl либо в коде, указывая массив: При выборе пункта (не выбрано)-> и без указания вычисления полей в строках ниже (т.е. если задан пустой массив) ничего отображаться не будет. | |
Свойства раздела | SECTION_USER_FIELDS | Указываются свойства раздела, которые будут отображены на странице. Заполняется из публичной части редактора, удерживая клавишу Ctrl либо в коде, указывая массив. При выборе пункта (не выбрано)-> и без указания вычисления полей в строках ниже, свойства не будут выведены. | |
Имя массива со значениями фильтра разделов | FILTER_NAME | Задается имя переменной, в которую передается массив параметров из фильтра. Если имя массива не указано, то будет использоваться значение по умолчанию. | |
Внешний вид (для шаблона .default и visual) | |||
Вид списка подразделов | VIEW_MODE | Определяется способ отображения списка подразделов: в виде списка (LINE), многоуровнего списка (LIST), текста (TEXT) или плитки (TILE). | |
Показывать название раздела | SHOW_PARENT_NAME | [Y|N] При отмеченной опции будет выводится название раздела (кроме раздела верхнего уровня). | |
Шаблоны ссылок | |||
URL, ведущий на страницу с содержимым раздела | SECTION_URL | Указывается путь к странице с содержимым раздела. | |
Настройки кеширования | |||
Тип кеширования | CACHE_TYPE | Тип кеширования:
| |
Время кеширования (сек.) | CACHE_TIME | Время кеширования, указанное в секундах. | |
Учитывать права доступа | CACHE_GROUPS | [Y|N] При отмеченной опции будут учитываться права доступа при кешировании. | |
Дополнительные настройки | |||
Включать раздел в цепочку навигации | ADD_SECTIONS_CHAIN | [Y|N] При отмеченной опции название или заголовок (если задан в настройках SEO) раздела будет включен в цепочку навигации. | |
Служебные параметры (не отображаются в настройках компонента) | |||
Кастомная сортировка по произвольному числу параметров | CUSTOM_SECTION_SORT | Данный служебный параметр можно передать в вызове компонента. Тип параметра — массив. Структура массива соответствует ключу $arOrder метода CIBlockSection::GetList. | Доступно с версии модуля iblock 20.0.400. Параметр не используется в штатных шаблонах комплексного компонента catalog. |
Пример вызова
Пользовательские комментарии
Мы будем рады, если разработчики добавят свои комментарии по практическому использованию методов системы.
Для этого нужно всего лишь авторизоваться на сайте
Но помните, что Пользовательские комментарии, несмотря на модерацию, не являются официальной документацией. Ответственность за их использование несет сам пользователь.
Также Пользовательские комментарии не являются местом для обсуждения функционала. По подобным вопросам обращайтесь на форумы.
Чтобы выбрать все пользовательские поля раздела укажите
Источник
Bitrix catalog.section как сделать вывод разделов и элементов?
Нужно вывести элементы отсортированные по разделам на одной странице.
Например: Раздел 1<Элемент1, Элемент2, Элемент3>, потом на этой же странице ниже Раздел 2 <Элемент1, элемент2, элемент3>и.т.д.
Через result_modifer смог получить название раздела для каждого элемента:
foreach ($arResult[‘ITEMS’] as $key => $arItem)
<
$arSectionList = array();
$rsSections = CIBlockElement::GetElementGroups($arItem[‘ID’]);
while ($arSection = $rsSections->Fetch())
<
$arSectionList[] = array(
‘ID’ => $arSection[‘ID’],
‘NAME’ => $arSection[‘NAME’],
);
>
$arItem[‘SECTION_NAME’] = $arSectionList;
$arResult[‘ITEMS’][$key] = $arItem;
>
Теперь хочу собрать массив вида Раздел 1<Элемент1, Элемент2, Элемент3>. Подскажите решение.
- Вопрос задан более трёх лет назад
- 29229 просмотров
Запрос в цикле — ай-яй-яй, как плохо.
А вообще вот прямо для этого решения:
И на выходе получишь $arResult[‘ITEMS_BY_GROUP’] где ключами будут ID разделов, а значениями массивы содержащие ключи элементов ITEMS принадлежащих этому разделу.
Но если много элементов то вот это вот: CIBlockElement::GetElementGroups надо выносить за пределы цикла.
в result_modifier.php изменить
Мне человек для вывода отдельными группами элементов из подразделов предложил вот такой вариант:
в result_modifier.php шаблона вывода списка примерно так:
в template.php обычный цикл по $arResult[‘COL_циферка’] 3 раза и фильтр в таком случае не нужен.
Самый простой способ, «в лоб»:
Если каталог небольшой ( CIBlockSection::GetTreeList()
Далее перебираем полученный массив разделов и для каждого раздела выбираем все принадлежащие ему элементы
CIBlockElement::GetList()
— но будет огромное кол-во лишних запросов. Можно обойтись двумя:
1. выбираем все разделы CIBlockSection::GetTreeList()
2. выбираем все элементы CIBlockElement::GetList()
3. объединяем два массива в один.
Источник
Битрикс: как узнать список разделов и элементов
Бывают ситуации, когда нужно вывести список элементов или разделов конкретного информационного блока (инфоблока). Воспользуемся CIBlockElement::GetList для элементов и CIBlockSection::GetList для разделов соответственно.
Как вывести список элементов инфоблока в 1С-Битрикс
Для этого создадим тестовую страницу в корне нашего сайта, например test.php . Код нашего файла будет иметь следующий вид:
Как видим, подключается header и footer (заголовок нам не нужен в принципе). Теперь напишем код CIBlockElement::GetList между подключением header и footer.
Код мы написали, теперь давайте посмотрим что мы делаем:
- подключаем модуль iblock т.к. без него наш код может не работать;
- задаем переменную, которая равна ID необходимого информационного блока (в моем случае это 14);
- в переменную записываем CIBlockElement::GetList, иначе не сможем с ним работать;
- в CIBlockElement::GetList есть массивы с данными:
Array(«ID» => «ASC») — массив для сортировки, в нашем случае это ID по возрастанию,
Array(«IBLOCK_ID» => $iblock_id) — массив для фильтрации — мы выбрали только по ID инфоблока,
false, false — тут можно задать массивы для группировки элементов и выбрать параметры постраничной навигации (как правило, они не нужны, ставим каждому false),
Array(‘ID’, ‘NAME’, ‘DETAIL_PAGE_URL’) — последний, но не менее важный массив, который вернет выбранные поля. В нашем случае он вернет ID, Имя элемента, полный путь к детальному элементу (его url). - выводим по очереди все наши элементы с помощью цикла.
urldecode — я использовал для правильного отображения кириллических урлов (да, их оказывается кто-то еще использует 🙂 ). $ar_fields[‘DETAIL_PAGE_URL’] — выведет вам в каждой строке ссылку на элемент, при желании, вы можете заменить DETAIL_PAGE_URL на ID или NAME и т.д. в зависимости от того, какая перед вами стоит задача.
Важно знать! Если вы не выбираете поля для последнего массива (который обычно называют arSelect), вы рискуете прилично загрузить ваш сервер, ведь он будет тащить для каждого элемента, значения всех его полей. Представьте сколько это запросов к БД.
Как узнать значения свойств инфоблока в Битриксе
Ну хорошо, мы выводим имя, id и ссылку — казалось бы, зачем весь этот цирк? А вот теперь рассмотрим случай, когда мы с помощью GetList можем узнать свойства инфоблока, конкретного элемента. Заменяем наш arSelect, он же массив с выбором полей на
Array(‘ID’, ‘NAME’, ‘DETAIL_PAGE_URL’, ‘PROREPTY_TITLE’)
где, TITLE — это символьный код вашего свойства (а приписка PROREPTY_ служит как раз для того чтобы это и указать).
Отобразить на экран свойство битрикса можно несколькими способами, в зависимости от его типа — строка это или список. Это может быть как
Если у вас что-то не получается, давайте просто выведем список элементов массива:
Кстати, если у вас много элементов в массиве, то для такой цели лучше вывести всего поля первого элемента (это может быть товар, новость и т.д.). Как это сделать? Либо дописать в GetList строку
либо создать счетчик перед массивом и вывести для 1 элемента, примерно вот так:
ПС — показал где писать nTopCount 🙂
Как вывести список разделов в 1С Битрикс
Описание почти такое же как и в предыдущим примере, но советую все же глянуть описание полей и возможных вариантов в официальной документации.
Если вы заметили, у нас теперь массив с выбором по порядку четвертый а не пятый и добавился параметр » ACTIVE» => «Y» , который выводит только активные «разделы»(это работает и для CIBlockElement, просто в данном скрипте нашими элеменами являются разделы инфоблока). Принцип работы с CIBlockSection::GetList почти такой же, как и с CIBlockElement. В данном скрипте мы выводим символьный код разделов, предварительно преобразовав в читаемую кириллицу.
автор: Dmitriy
Занимаюсь веб-разработкой с 2011 года. Посмотреть некоторые из моих работ, а также узнать чуть больше обо мне, вы можете на forwww.ru.
— Создание сайтов на 1С-Битрикс любой сложности
— Вёрстка макетов Figma, Photoshop, Zeplin
— Поддержка проектов на Битриксе
— Разработка нового функционала для сайта
— Парсинг данных
— Выгрузка \ Загрузка файлов в формате XML, YML, XLS, XLSX, CSV, JSON
— Интеграция по API со сторонними сервисами
и многое другое
Источник